亚洲一级电影在线观看,九九精品无码专区免费,亚洲AV无码资源在线观看 ,欧美国产高清

深入PHP中的HashTable結構詳解

時間:2024-07-01 21:50:41 PHP 我要投稿
  • 相關推薦

深入PHP中的HashTable結構詳解

  深入PHP中的HashTable結構詳解

  對php內核有一定了解的人應該都知道php的精髓就是HashTable,HashTable在php的實現中無處不在。包括php的數組、什么全局變量、局部變量的作用域等等,php的hashtable拆開來說就是四部分:

  hash函數:用的是time33的散列函數,將一個字符串的'key轉換成一個數字

  一個C數組:用來儲存桶(buckets)的

  兩個雙向的鏈表:第一個雙向鏈表是數組的每個元素(桶bucket)是一個雙向鏈表,這樣做是為了解決hash沖突;第二個雙向鏈表是數組將每一個桶(bucket)連接起來,這里要連接的也就是第一個雙向鏈表的鏈表頭,這樣做是為了遍歷整個hash表用的,鳥哥有篇blog是講php的foreach的,這里這樣設計就是給foreach用的==>《深入理解PHP之數組(遍歷順序)》

  我這里不再說hashtable的struct和bucket的struct了,因為下面的推薦鏈接幾乎都講了,我不覺得我能描述和說的比他們好,每個人的水平不一樣,我就以我現在的技術水平來描述,所以我就只把我整理的一些東西記錄一下

  下面是php中hash實現的兩個文件:zend_hash.c zend_hash.h。這兩個文件里面實現了一堆的api,也引申出了一堆的api,下面是實現出來的api的原型

  復制代碼 代碼如下:

  ZEND_API ulong zend_hash_func(const char *arKey, uint nKeyLength)

  ZEND_API ulong zend_get_hash_value(const char *arKey, uint nKeyLength)

  ZEND_API int _zend_hash_init(HashTable *ht, uint nSize, hash_func_t pHashFunction, dtor_func_t pDestructor, zend_bool persistent ZEND_FILE_LINE_DC)

  ZEND_API void zend_hash_set_apply_protection(HashTable *ht, zend_bool bApplyProtection)

  ZEND_API int _zend_hash_add_or_update(HashTable *ht, const char *arKey, uint nKeyLength, void *pData, uint nDataSize, void **pDest, int flag ZEND_FILE_LINE_DC)

  ZEND_API int _zend_hash_quick_add_or_update(HashTable *ht, const char *arKey, uint nKeyLength, ulong h, void *pData, uint nDataSize, void **pDest, int flag ZEND_FILE_LINE_DC)

  ZEND_API int _zend_hash_index_update_or_next_(HashTable *ht, ulong h, void *pData, uint nDataSize, void **pDest, int flag ZEND_FILE_LINE_DC)

  ZEND_API int zend_hash_rehash(HashTable *ht)

  static int zend_hash_do_resize(HashTable *ht)

  ZEND_API int zend_hash_del_key_or_index(HashTable *ht, const char *arKey, uint nKeyLength, ulong h, int flag)

  ZEND_API void zend_hash_destroy(HashTable *ht)

  ZEND_API void zend_hash_clean(HashTable *ht)

  static Bucket *zend_hash_apply_r(HashTable *ht, Bucket *p)

  ZEND_API void zend_hash_graceful_destroy(HashTable *ht)

  ZEND_API void zend_hash_graceful_reverse_destroy(HashTable *ht)

  ZEND_API void zend_hash_apply(HashTable *ht, apply_func_t apply_func TSRMLS_DC)

  ZEND_API void zend_hash_apply_with_argument(HashTable *ht, apply_func_arg_t apply_func, void *argument TSRMLS_DC)

  ZEND_API void zend_hash_apply_with_arguments(HashTable *ht TSRMLS_DC, apply_func_args_t apply_func, int num_args, …)

  ZEND_API void zend_hash_reverse_apply(HashTable *ht, apply_func_t apply_func TSRMLS_DC)

  ZEND_API void zend_hash_copy(HashTable *target, HashTable *source, copy_ctor_func_t pCopyConstructor, void *tmp, uint size)

  ZEND_API void _zend_hash_merge(HashTable *target, HashTable *source, copy_ctor_func_t pCopyConstructor, void *tmp, uint size, int overwrite ZEND_FILE_LINE_DC)

  static zend_bool zend_hash_replace_checker_wrapper(HashTable *target, void *source_data, Bucket *p, void *pParam, merge_checker_func_t merge_checker_func)

  ZEND_API void zend_hash_merge_ex(HashTable *target, HashTable *source, copy_ctor_func_t pCopyConstructor, uint size, merge_checker_func_t pMergeSource, void *pParam)

  ZEND_API int zend_hash_find(const HashTable *ht, const char *arKey, uint nKeyLength, void **pData)

  ZEND_API int zend_hash_quick_find(const HashTable *ht, const char *arKey, uint nKeyLength, ulong h, void **pData)

  ZEND_API int zend_hash_exists(const HashTable *ht, const char *arKey, uint nKeyLength)

  ZEND_API int zend_hash_quick_exists(const HashTable *ht, const char *arKey, uint nKeyLength, ulong h)

  ZEND_API int zend_hash_index_find(const HashTable *ht, ulong h, void **pData)

  ZEND_API int zend_hash_index_exists(const HashTable *ht, ulong h)

  ZEND_API int zend_hash_num_elements(const HashTable *ht)

  ZEND_API int zend_hash_get_pointer(const HashTable *ht, HashPointer *ptr)

  ZEND_API int zend_hash_set_pointer(HashTable *ht, const HashPointer *ptr)

  ZEND_API void zend_hash_internal_pointer_reset_ex(HashTable *ht, HashPosition *pos)

  ZEND_API void zend_hash_internal_pointer_end_ex(HashTable *ht, HashPosition *pos)

  ZEND_API int zend_hash_move_forward_ex(HashTable *ht, HashPosition *pos)

  ZEND_API int zend_hash_move_backwards_ex(HashTable *ht, HashPosition *pos)

  ZEND_API int zend_hash_get_current_key_ex(const HashTable *ht, char **str_index, uint *str_length, ulong *num_index, zend_bool duplicate, HashPosition *pos)

  ZEND_API int zend_hash_get_current_key_type_ex(HashTable *ht, HashPosition *pos)

  ZEND_API int zend_hash_get_current_data_ex(HashTable *ht, void **pData, HashPosition *pos)

  ZEND_API int zend_hash_update_current_key_ex(HashTable *ht, int key_type, const char *str_index, uint str_length, ulong num_index, int mode, HashPosition *pos)

  ZEND_API int zend_hash_sort(HashTable *ht, sort_func_t sort_func, compare_func_t compar, int renumber TSRMLS_DC)

  ZEND_API int zend_hash_compare(HashTable *ht1, HashTable *ht2, compare_func_t compar, zend_bool ordered TSRMLS_DC)

  ZEND_API int zend_hash_minmax(const HashTable *ht, compare_func_t compar, int flag, void **pData TSRMLS_DC)

  ZEND_API ulong zend_hash_next_free_element(const HashTable *ht)

  void zend_hash_display_pListTail(const HashTable *ht)

  void zend_hash_display(const HashTable *ht)

【深入PHP中的HashTable結構詳解】相關文章:

關于深入PHP內存相關的功能特性詳解09-02

php多進程編程詳解201706-04

PHP中curl的使用實例07-31

英語基本語法結構詳解10-25

PHP中關于類的定義10-02

linux操作系統目錄結構詳解07-17

GRE考試難句語法結構詳解01-22

PHP中函數的使用說明09-01

PHP中的排序函數區別分析08-23

教育碩士輔導之詳解教育的結構與功能12-03

主站蜘蛛池模板: 亚洲伊人情人综合网站| 国产高潮流白浆视频| 欧美区国产区| 人妻被修空调在夫面侵犯| 99久久99这里只有免费费精品| 中文字幕人妻丝袜成熟乱| 欧美成人免费全部观看国产| 337p粉嫩大胆色噜噜噜| 国产亚洲精品在av| 在线亚洲精品福利网址导航| 97超级碰碰碰碰精品| 久久国产精品久久精| 东京热无码一区二区三区分类视频| 色婷婷狠狠97成为人免费| 欧美性猛交xxx嘿人猛交| 曰批免费视频播放免费直播| 日本护士╳╳╳hd少妇| 国产日韩一区二区三区在线观看| 精品人妻二区中文字幕| 久久丫精品忘忧草西安产品| 中国做爰国产精品视频| 一本大道东京热无码一区 | 天天躁日日躁狠狠躁视频2021| 亚洲色一区二区三区四区| 国产精品亚洲а∨天堂网不卡 | 亚洲成国产人片在线观看| 精品国产人妻一区二区三区| 欧美性大战久久久久久久| 一本加勒比hezyo无码资源网| 精品无码久久久久久尤物| 人妻精品久久久久中文字幕| 丰满少妇高潮惨叫正在播放| 国产福利在线永久视频| 亚洲第一尤物视频在线观看导航| 欧美亚洲一二三区| 国产综合18久久久久久| 中国猛少妇色xxxxx| 久久超乳爆乳中文字幕| 芜湖县| 园内精品自拍视频在线播放| 一本一本久久a久久精品综合不卡|