ホームページ >バックエンド開発 >PHPの問題 >PHPハッシュテーブルとは何ですか?

PHPハッシュテーブルとは何ですか?

Guanhui
Guanhuiオリジナル
2020-06-24 14:26:212918ブラウズ

PHPハッシュテーブルとは何ですか?

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ハッシュテーブルとは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。