PHP 配列の深い理解 (走査順序) Laruence Original_PHP チュートリアル
よく質問されますが、foreach を使用して PHP 配列にアクセスする場合、トラバーサルの順序は決まっていますか?
例:
$arr['laruence'] = 'huixinchen';
$arr['baidu'] = 2008; ($arr as $key => $val) {
//結果は何ですか?
}
別の例:
コードは次のとおりです:
//これを完全に理解するには?まず第一に、誰もが PHP 配列の内部実装構造を理解する必要があると思います...
PHP 配列
PHP では、配列は HASH 構造 (HashTable) を使用して実装されます。 O( 1) 最小限の時間計算で配列の追加と削除を実装し、線形トラバーサルとランダム アクセスを同時にサポートします
これまでの記事でも説明しましたが、これに基づいてさらに拡張を行います。
HashTable について理解する前に、まず HashTable の構造定義を見てみましょう:
コードをコピー
コードは次のとおりです:
typedef struct _hashtable {
uint nTableSize; /* ハッシュ テーブルのサイズ、ハッシュ値の間隔*/
dtor_func_t pDestructor;/* 要素のデストラクタ (ポインタ) */
zend_boolpersistent;
unsigned char nApplyCount; /* ループトラバーサル保護* /
zend_debug
#endif
} HashTable; applyCount、理解できます例を通して:
コードをコピー
コードは次のとおりです:
$arr = array(1,2,3,4,5,);
$arr[] = & $arr;
上記の構造を見ると、このフィールドは循環参照によって引き起こされる無限ループを防ぐために設定されています。 HashTable の場合、キー要素は実際のストレージ コンテナである arBuckets であることがわかります。その構造定義を見てみましょう:
typedef struct Bucket。 {
ulong h; /* 数値インデックス/ハッシュ値*/
uint nKeyLength; /* 文字インデックスの長さ* /
void *pData; /* データポインタ*/
構造体*pListNext; /* 次の要素、線形走査用*/
struct Bucket *pNext; /* 同じジッパー内の次の要素*/
struct Bucket *pLast; /* 同じジッパー内の前の要素*/
char arKey[1 ]; /* メモリを節約し、初期化を容易にするためのヒント*/
最後の要素は、メモリを節約し、初期化を容易にする柔軟な配列手法であることに気付きました。興味のある方は、柔軟な配列を検索してください。
h は要素のハッシュ値であり、数値的にインデックス付けされた要素の場合は、h です。直接のインデックス値 (nKeyLength=0 で表される数値インデックス) 文字列インデックスの場合、インデックス値は arKey に格納され、インデックスの長さは nKeyLength に格納されます。 pData ポインタが指すメモリ ブロック。通常、このメモリ ブロックはシステムによって個別に割り当てられます。ただし、例外があります。つまり、バケットによって保存されたデータがポインターの場合、HashTable はシステムにポインターを保存するためのスペースの割り当てを要求せず、ポインターを pDataPtr に直接保存し、pData をメンバーにポイントします。この構造体のアドレス。これにより効率が向上し、メモリの断片化が軽減されます。このことから、PHP HashTable の設計の微妙な点がわかります。 Bucket 内のデータがポインターではない場合、pDataPtr は NULL になります (この段落は Altair の「Zend HashTable 詳細説明」から引用しています)
上記の HashTable 構造と組み合わせて、HashTable の一般的な構造図を図解してみましょう:

pInternalPointer は、配列を順次に走査する場合、このポインターは現在の要素を示します。 Bucket.pListNext/pListLast は、pInternalPointer の移動に基づいてすべての要素の線形トラバーサルを実装します
たとえば、foreach の場合、生成されるオペコード シーケンスを見ると、foreach の前に最初に FE_RESET が存在することがわかります。配列 pInternalPointer である内部ポインター (foreach については、PHP の原理を詳しく理解するために foreach を参照してください) であり、各 FE_FETCH を通じて pInternalPointer をインクリメントして、順次走査を実現します
同様に、 each/next を使用する場合。走査する一連の関数 この場合、配列の内部ポインタを移動することによっても順次走査が可能になります。たとえば、次のような問題があります。
コードをコピー
while (list($key, $v) = each( $arr)) {
//can't get To
}
?>
今紹介した知識を理解すれば、foreach は自動的にリセットされますが、while ブロックはリセットされないため、この問題は非常に明確になります。したがって、foreach が終了すると、pInternalPointer は配列を指します。もちろん、最後には while ステートメントのブロックにアクセスできなくなります。解決策は、それぞれの前に配列の内部ポインターをリセットすることです。
そして、ランダム アクセス中に、位置がリセットされます。ハッシュ配列の先頭ポインターの位置はハッシュ値によって決まります。次に、pNext/pLast を使用して特徴的な要素を見つけます。
要素を追加する場合、要素は同じハッシュ要素チェーンの先頭と末尾に挿入されます。つまり、線形リストの要素は、線形トラバース中に挿入順序に従って挿入されます。この特別な設計により、PHP では、数値インデックスを使用する場合、要素の順序は追加の順序によって決まります。
言い換えると、PHP で配列を走査する順序は、要素を追加する順序に関連しているため、記事の冒頭の質問の出力が次のようになることは明らかです。
コードをコピーします
コードは次のとおりです:
huixinchen
2007
コードをコピーします
コードは次のとおりです:
for($i=0,$l=count( $arr); $i//このとき、逐次トラバーサル (線形トラバーサル) として考慮することはできません
http://www.bkjia.com/PHPjc/325561.html
www.bkjia.com
true
http://www.bkjia.com/PHPjc/325561.html

PHPでは、特性は方法が必要な状況に適していますが、継承には適していません。 1)特性により、クラスの多重化方法が複数の継承の複雑さを回避できます。 2)特性を使用する場合、メソッドの競合に注意を払う必要があります。メソッドの競合は、代替およびキーワードとして解決できます。 3)パフォーマンスを最適化し、コードメンテナビリティを改善するために、特性の過剰使用を避け、その単一の責任を維持する必要があります。

依存関係噴射コンテナ(DIC)は、PHPプロジェクトで使用するオブジェクト依存関係を管理および提供するツールです。 DICの主な利点には、次のものが含まれます。1。デカップリング、コンポーネントの独立したもの、およびコードの保守とテストが簡単です。 2。柔軟性、依存関係を交換または変更しやすい。 3.テスト可能性、単体テストのために模擬オブジェクトを注入するのに便利です。

SplfixedArrayは、PHPの固定サイズの配列であり、高性能と低いメモリの使用が必要なシナリオに適しています。 1)動的調整によって引き起こされるオーバーヘッドを回避するために、作成時にサイズを指定する必要があります。 2)C言語アレイに基づいて、メモリと高速アクセス速度を直接動作させます。 3)大規模なデータ処理とメモリに敏感な環境に適していますが、サイズが固定されているため、注意して使用する必要があります。

PHPは、$ \ _ファイル変数を介してファイルのアップロードを処理します。セキュリティを確保するための方法には次のものが含まれます。1。アップロードエラー、2。ファイルの種類とサイズを確認する、3。ファイル上書きを防ぐ、4。ファイルを永続的なストレージの場所に移動します。

JavaScriptでは、nullcoalescingoperator(??)およびnullcoalescingsignmentoperator(?? =)を使用できます。 1.??最初の非潜水金または非未定されたオペランドを返します。 2.??これらの演算子は、コードロジックを簡素化し、読みやすさとパフォーマンスを向上させます。

XSS攻撃を防ぎ、リソースのロードを制限し、ウェブサイトのセキュリティを改善できるため、CSPは重要です。 1.CSPはHTTP応答ヘッダーの一部であり、厳格なポリシーを通じて悪意のある行動を制限します。 2。基本的な使用法は、同じ起源からのロードリソースのみを許可することです。 3.高度な使用法は、特定のドメイン名がスクリプトやスタイルをロードできるようにするなど、より微調整された戦略を設定できます。 4。CSPポリシーをデバッグおよび最適化するには、コンテンツセキュリティポリシーレポートのみのヘッダーを使用します。

HTTPリクエストメソッドには、それぞれリソースを取得、送信、更新、削除するために使用されるGET、POST、PUT、および削除が含まれます。 1. GETメソッドは、リソースを取得するために使用され、読み取り操作に適しています。 2. POSTメソッドはデータの送信に使用され、新しいリソースを作成するためによく使用されます。 3. PUTメソッドは、リソースの更新に使用され、完全な更新に適しています。 4.削除メソッドは、リソースの削除に使用され、削除操作に適しています。

HTTPSは、HTTPに基づいてセキュリティレイヤーを追加するプロトコルであり、主に暗号化されたデータを介してユーザーのプライバシーとデータセキュリティを保護します。その作業原則には、TLSの握手、証明書の確認、暗号化された通信が含まれます。 HTTPSを実装する場合、証明書管理、パフォーマンスへの影響、および混合コンテンツの問題に注意を払う必要があります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 中国語版
中国語版、とても使いやすい

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ホットトピック



