一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

深入PHP中的HashTable結(jié)構(gòu)詳解

HashTable是Zend引擎中最重要、使用最廣泛的數(shù)據(jù)結(jié)構(gòu),它被用來存儲(chǔ)幾乎所有的東西。
1.2.1 數(shù)據(jù)結(jié)構(gòu)
HashTable數(shù)據(jù)結(jié)構(gòu)定義如下:
復(fù)制代碼 代碼如下:
typedef struct bucket {
 ulong h;    // 存放hash
 uint nKeyLength;
 void *pData;   // 指向value,是用戶數(shù)據(jù)的副本
 void *pDataPtr;
 struct bucket *pListNext; // pListNext和pListLast組成
 struct bucket *pListLast; // 整個(gè)HashTable的雙鏈表
 struct bucket *pNext;  // pNext和pLast用于組成某個(gè)hash對(duì)應(yīng)
 struct bucket *pLast;  // 的雙鏈表
 char arKey[1];    // key
} Bucket;

typedef struct _hashtable {
 uint nTableSize;
 uint nTableMask;
 uint nNumOfElements;
 ulong nNextFreeElement;
 Bucket *pInternalPointer; /* Used for element traversal */
 Bucket *pListHead;
 Bucket *pListTail;
 Bucket **arBuckets;   // hash數(shù)組
 dtor_func_t pDestructor; // HashTable初始化時(shí)指定,銷毀Bucket時(shí)調(diào)用
 zend_bool persistent;  // 是否采用C的內(nèi)存分配例程
 unsigned char nApplyCount;
 zend_bool bApplyProtection;
#if ZEND_DEBUG
 int inconsistent;
#endif
} HashTable;

總的來說,Zend的HashTable是一種鏈表散列,同時(shí)也為線性遍歷進(jìn)行了優(yōu)化,圖示如下:


HashTable中包含兩種數(shù)據(jù)結(jié)構(gòu),一個(gè)鏈表散列和一個(gè)雙向鏈表,前者用于進(jìn)行快速鍵-值查詢,后者方便線性遍歷和排序,一個(gè)Bucket同時(shí)存在于這兩個(gè)數(shù)據(jù)結(jié)構(gòu)中。
關(guān)于該數(shù)據(jù)結(jié)構(gòu)的幾點(diǎn)解釋:
鏈表散列中為什么使用雙向鏈表?
一般的鏈表散列只需要按key進(jìn)行操作,只需要單鏈表就夠了。但是,Zend有時(shí)需要從鏈表散列中刪除給定的Bucket,使用雙鏈表可以非常高效的實(shí)現(xiàn)。
nTableMask是干什么的?
這個(gè)值用于hash值到arBuckets數(shù)組下標(biāo)的轉(zhuǎn)換。當(dāng)初始化一個(gè)HashTable,Zend首先為arBuckets數(shù)組分配nTableSize大小的內(nèi)存,nTableSize取不小于用戶指定大小的最小的2^n,即二進(jìn)制的10*。nTableMask = nTableSize

主站蜘蛛池模板: 婷婷色在线 | 四虎国产永久在线精品免费观看 | 一区二区三区四区五区 | 亚洲区激情区图片小说区 | 日本成人福利视频 | 凹凸精品视频分类国产品免费 | 中文成人在线视频 | 一区二区免费看 | 日韩国产一区二区 | 久久精选视频 | 好吊妞视频在线观看 | 在线亚洲激情 | 在线小毛片 | 久草久操 | 成年人视频在线观看免费 | 亚洲日本一区二区三区高清在线 | 五月天天色 | 久久精品爱国产免费久久 | 色婷婷在线播放 | 成年网站未满十八禁毛片免费 | 久久久久亚洲视频 | 就要爱综合 | 69国产成人精品午夜福中文 | 欧美激情区 | 久久国产成人精品麻豆 | 亚洲香蕉久久综合网 | 国产精品久久自在自2021 | 成年美女黄的视频网站 | 久艾草国产成人综合在线视频 | 国产欧美一区二区三区免费 | 2021国产麻豆剧 | 国产成人香蕉 | 91av在线导航 | 国产黄色小视频 | 全色黄大色大片免费久久老太 | 婷婷伊人五月 | 国产日韩欧美不卡www | 在线一区二区三区 | 欧美日韩看看2015永久免费 | 高清在线亚洲精品国产二区 | 2020国产成人精品视频人 |