ホームページ >バックエンド開発 >PHPチュートリアル >PHP の配列モデルに関するいくつかの推測 (misko lee 著)_PHP チュートリアル

PHP の配列モデルに関するいくつかの推測 (misko lee 著)_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 17:54:111004ブラウズ

私の個人的な理解によれば、配列はメモリ内の連続した空間であるべきです。配列を使用する前に、指定されたサイズの空のメモリをメモリ内で開く必要があります。宣言されたサイズが使用可能な連続メモリ サイズより小さい場合は、メモリ オーバーフロー エラーが報告されます。
PHP 配列を使用したことがある子供たちは、PHP の配列には上記の特性がないことをすぐに判断できるはずです。第一に、配列宣言のサイズを決定する必要がありません。第二に、配列の使用に上限がありません。この 2 つの点から、PHP の配列は連続したメモリ空間ではなく、リンクされたリストの緩やかな構造であると判断できます。
PHP の配列は、インデックス付き配列と連想配列の 2 つの形式に分類できます。インデックス配列はカウント配列構造です。連想配列は、キーと値の構造であるマップ データ構造の実装です。
次の例を通じて、インデックス付き配列と連想配列について説明します。
$arr=array(1,2,3,'name'=>'misko_lee','age'=>22); //インデックス付きの結合配列を定義します
for($i=0;$i echo $arr[$i]; //ここで添字オーバーフローのエラーメッセージが表示されます

Cout($arr) 関数呼び出しは、$arr 配列の長さを返します。ただし、for ループは通常インデックス配列しか出力できません。したがって、インデックス配列と連想配列は 2 つの異なる実装であると判断できます。これは、PHP の配列が緩やかな構造をしているという推測も証明しています。
インデックス配列については次のような推測もあります:
$arr[100]=100;
$arr[]=101; //このとき、自動的に増加する$arr[]のインデックスは101です。

上記の実験は、PHP の配列カウンターは配列メモリの先頭アドレスからカウントを開始するのではなく、擬似的なカウント方法であることを証明しました。したがって、配列のサイズを決定するためにカウンターを使用することは完全に間違っています。
上記の発言は個人的な戯言であり、極めて信頼性が低いものです。先輩方は間違いを指摘していただければ幸いです。善良な人は安全な生活を送っています。
最後の追記: foreach を使用して配列を走査した後、要求によるものではない場合は、reset() 関数を使用して配列ポインターをリセットしてください

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/477973.html技術記事私の個人的な理解によれば、配列はメモリ内の連続した空間であるべきです。配列を使用する前に、宣言されたサイズが...
より小さい場合、メモリ内に指定されたサイズの空のメモリを開く必要があります。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。