ホームページ >バックエンド開発 >PHPチュートリアル >PHP の配列モデルに関するいくつかの推測 (misko lee 著)_PHP チュートリアル
私の個人的な理解によれば、配列はメモリ内の連続した空間であるべきです。配列を使用する前に、指定されたサイズの空のメモリをメモリ内で開く必要があります。宣言されたサイズが使用可能な連続メモリ サイズより小さい場合は、メモリ オーバーフロー エラーが報告されます。
PHP 配列を使用したことがある子供たちは、PHP の配列には上記の特性がないことをすぐに判断できるはずです。第一に、配列宣言のサイズを決定する必要がありません。第二に、配列の使用に上限がありません。この 2 つの点から、PHP の配列は連続したメモリ空間ではなく、リンクされたリストの緩やかな構造であると判断できます。
PHP の配列は、インデックス付き配列と連想配列の 2 つの形式に分類できます。インデックス配列はカウント配列構造です。連想配列は、キーと値の構造であるマップ データ構造の実装です。
次の例を通じて、インデックス付き配列と連想配列について説明します。
$arr=array(1,2,3,'name'=>'misko_lee','age'=>22); //インデックス付きの結合配列を定義します
for($i=0;$i
Cout($arr) 関数呼び出しは、$arr 配列の長さを返します。ただし、for ループは通常インデックス配列しか出力できません。したがって、インデックス配列と連想配列は 2 つの異なる実装であると判断できます。これは、PHP の配列が緩やかな構造をしているという推測も証明しています。
インデックス配列については次のような推測もあります:
$arr[100]=100;
$arr[]=101; //このとき、自動的に増加する$arr[]のインデックスは101です。
上記の実験は、PHP の配列カウンターは配列メモリの先頭アドレスからカウントを開始するのではなく、擬似的なカウント方法であることを証明しました。したがって、配列のサイズを決定するためにカウンターを使用することは完全に間違っています。
上記の発言は個人的な戯言であり、極めて信頼性が低いものです。先輩方は間違いを指摘していただければ幸いです。善良な人は安全な生活を送っています。
最後の追記: foreach を使用して配列を走査した後、要求によるものではない場合は、reset() 関数を使用して配列ポインターをリセットしてください