中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

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

HashTable是Zend引擎中最重要、使用最廣泛的數(shù)據(jù)結(jié)構(gòu),它被用來存儲幾乎所有的東西。
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; // 整個HashTable的雙鏈表
 struct bucket *pNext;  // pNext和pLast用于組成某個hash對應(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初始化時指定,銷毀Bucket時調(diào)用
 zend_bool persistent;  // 是否采用C的內(nèi)存分配例程
 unsigned char nApplyCount;
 zend_bool bApplyProtection;
#if ZEND_DEBUG
 int inconsistent;
#endif
} HashTable;

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


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

主站蜘蛛池模板: 一级片毛片| 久草福利 | 国产91久久精品一区二区 | 亚洲三区在线 | 一级黄色淫片 | 久久草视频| 日韩一二三区视频 | 91精品导航 | 91天堂| 亚洲欧美国产视频 | 国产成人精品午夜视频免费 | 中文字幕亚洲视频 | 精品啪啪 | 国产视频精品免费 | 国产成人免费视频网站高清观看视频 | 亚洲国产精品网站 | 欧美午夜激情在线 | 中文字幕人成乱码在线观看 | 亚洲综合色站 | 麻豆精品国产91久久久久久 | 亚洲精品一 | 欧美日韩一 | www.788.com色淫免费 | 欧美偷偷| 欧美 日韩 国产 一区 | 自拍偷拍中文字幕 | 一本一道久久a久久精品综合蜜臀 | 久久国产精品一区二区三区 | 亚洲欧美日韩精品久久亚洲区 | 午夜成人免费电影 | www.成人.com | 丝袜美腿一区 | 国产精品免费一区二区 | 欧美久久天堂 | 97超碰站| 亚洲国产69 | 日本在线免费看最新的电影 | 欧美一级一 | 日韩av网址在线观看 | 九九看片 | 亚洲成人精品 |