PHP ハッシュテーブルとは何ですか?
PHP HashTable は、キー値に基づいて直接アクセスされるデータ構造であるハッシュ テーブルを指します。つまり、キー値をテーブル内の場所にマッピングすることでレコードにアクセスできます。検索を高速化するために、レコードを格納する配列はハッシュ テーブルです。
HashTable の新しいバージョン
hashtable の古いバージョンと比較すると、変更点はかなり大きくなります
要素旧バージョンの要素ストレージは分散している Bucket **arBucketsにはバケットを指すポインタのアドレスが格納される 新バージョンの要素ストレージは連続する Bucket *arData;
4つありますポインタ 新しいバージョンのバケットにはポインタが 1 つだけあり、ハッシュ衝突の場合にのみ使用されます
ポインタが 3 つ減りました。新しいバージョンのハッシュテーブルに従う方法。挿入オーダーのトラバーサルとハッシュ競合の解決
ハッシュテーブルの定義を見てください
typedef struct _zend_array HashTable; struct _zend_array { zend_refcounted_h gc; // gc 相关 union { // 联合体 struct { ZEND_ENDIAN_LOHI_4( zend_uchar flags, zend_uchar nApplyCount, zend_uchar nIteratorsCount, zend_uchar consistency) } v; uint32_t flags; } u; uint32_t nTableMask; // hash表的掩码 用来确定hsh Bucket *arData; // bucket数组 uint32_t *arHash; // hashtable 查找 大小为nTableMask 存放指向bucket的指针(疑问在源码定义中未看到) uint32_t nNumUsed; // 元素个数 包含已删除的元素 uint32_t nNumOfElements; // 有效的元素个数 uint32_t nTableSize; // hash表的大小 uint32_t nInternalPointer; zend_long nNextFreeElement; dtor_func_t pDestructor; };
バケットの定義
typedef struct _Bucket { zval val; zend_ulong h; //存的hash 值 用来寻找对比key zend_string *key; // 如果key是string 则存放key 如果是数字 则为空 } Bucket; typedef struct _zval_struct zval; struct _zval_struct { zend_value value; // value 真正的结构 union { struct { ZEND_ENDIAN_LOHI_4( zend_uchar type, /* active type */ zend_uchar type_flags, zend_uchar const_flags, zend_uchar reserved) /* call info for EX(This) */ } v; uint32_t type_info; } u1; union { uint32_t next; // 重点关注这个 存放hash 冲突下一个元素的位置 uint32_t cache_slot; /* literal cache slot */ uint32_t lineno; /* line number (for ast nodes) */ uint32_t num_args; /* arguments number for EX(This) */ uint32_t fe_pos; /* foreach position */ uint32_t fe_iter_idx; /* foreach iterator index */ uint32_t access_flags; /* class constant access flags */ uint32_t property_guard; /* single property guard */ uint32_t extra; /* not further specified */ } u2;
構造図
推奨チュートリアル: 「PHP」
以上がPHPハッシュテーブルとは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。