亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

php中hashtable實(shí)現(xiàn)示例分享

 更新時(shí)間:2014年02月13日 10:06:32   作者:  
對(duì)php內(nèi)核有一定了解的人應(yīng)該都知道php的精髓就是HashTable,這篇文章主要介紹了php中hashtable實(shí)現(xiàn)示例,需要的朋友可以參考下

對(duì)php內(nèi)核有一定了解的人應(yīng)該都知道php的精髓就是HashTable,HashTable在php的實(shí)現(xiàn)中無(wú)處不在。包括php的數(shù)組、什么全局變量、局部變量的作用域等等,php的hashtable拆開(kāi)來(lái)說(shuō)就是四部分:

hash函數(shù):用的是time33的散列函數(shù),將一個(gè)字符串的key轉(zhuǎn)換成一個(gè)數(shù)字
一個(gè)C數(shù)組:用來(lái)儲(chǔ)存桶(buckets)的
兩個(gè)雙向的鏈表:第一個(gè)雙向鏈表是數(shù)組的每個(gè)元素(桶bucket)是一個(gè)雙向鏈表,這樣做是為了解決hash沖突;第二個(gè)雙向鏈表是數(shù)組將每一個(gè)桶(bucket)連接起來(lái),這里要連接的也就是第一個(gè)雙向鏈表的鏈表頭,這樣做是為了遍歷整個(gè)hash表用的,鳥(niǎo)哥有篇blog是講php的foreach的,這里這樣設(shè)計(jì)就是給foreach用的==>《深入理解PHP之?dāng)?shù)組(遍歷順序)》
我這里不再說(shuō)hashtable的struct和bucket的struct了,因?yàn)橄旅娴耐扑]鏈接幾乎都講了,我不覺(jué)得我能描述和說(shuō)的比他們好,每個(gè)人的水平不一樣,我就以我現(xiàn)在的技術(shù)水平來(lái)描述,所以我就只把我整理的一些東西記錄一下

下面是php中hash實(shí)現(xiàn)的兩個(gè)文件:zend_hash.c zend_hash.h。這兩個(gè)文件里面實(shí)現(xiàn)了一堆的api,也引申出了一堆的api,下面是實(shí)現(xiàn)出來(lái)的api的原型

復(fù)制代碼 代碼如下:

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_insert(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_deleter(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)  

相關(guān)文章

  • laravel 5.3中自定義加密服務(wù)的方案詳解

    laravel 5.3中自定義加密服務(wù)的方案詳解

    這篇文章主要給大家介紹了在laravel 5.3中自定義加密服務(wù)的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用laravel 5.3具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-05-05
  • Laravel學(xué)習(xí)教程之本地化模塊

    Laravel學(xué)習(xí)教程之本地化模塊

    這篇文章主要給大家介紹了關(guān)于Laravel學(xué)習(xí)教程之本地化模塊的相關(guān)資料,文中通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-08-08
  • PHP函數(shù)in_array()使用詳解

    PHP函數(shù)in_array()使用詳解

    這篇文章主要介紹了PHP函數(shù)in_array()使用詳解,分別對(duì)普通使用、使用第三個(gè)參數(shù)、克隆對(duì)象、多維數(shù)組等給出了例子,需要的朋友可以參考下
    2014-08-08
  • PHP實(shí)現(xiàn)加密文本文件并限制特定頁(yè)面的存取的效果

    PHP實(shí)現(xiàn)加密文本文件并限制特定頁(yè)面的存取的效果

    本篇文章主要介紹了PHP實(shí)現(xiàn)加密文本文件并限制特定頁(yè)面的存取,可以限制用戶對(duì)某些頁(yè)面的存取,有需要的可以了解一下。
    2016-10-10
  • Laravel框架中擴(kuò)展函數(shù)、擴(kuò)展自定義類的方法

    Laravel框架中擴(kuò)展函數(shù)、擴(kuò)展自定義類的方法

    這篇文章主要介紹了Laravel框架中擴(kuò)展函數(shù)、擴(kuò)展自定義類的方法,非常實(shí)用的技術(shù)文章,需要的朋友可以參考下
    2014-09-09
  • 詳細(xì)Laravel5.5執(zhí)行表遷移命令出現(xiàn)表為空的解決方案

    詳細(xì)Laravel5.5執(zhí)行表遷移命令出現(xiàn)表為空的解決方案

    這篇文章主要介紹了詳細(xì)Laravel5.5執(zhí)行表遷移命令出現(xiàn)表為空的解決方案,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • php實(shí)現(xiàn)對(duì)短信驗(yàn)證碼發(fā)送次數(shù)的限制實(shí)例講解

    php實(shí)現(xiàn)對(duì)短信驗(yàn)證碼發(fā)送次數(shù)的限制實(shí)例講解

    這篇文章主要介紹了php實(shí)現(xiàn)對(duì)短信驗(yàn)證碼發(fā)送次數(shù)的限制實(shí)例講解,案例中列舉了具體代碼實(shí)現(xiàn),有感興趣的同學(xué)可以學(xué)習(xí)下
    2021-03-03
  • PHP實(shí)現(xiàn)文件上傳下載實(shí)例

    PHP實(shí)現(xiàn)文件上傳下載實(shí)例

    這篇文章主要介紹了PHP實(shí)現(xiàn)文件上傳下載實(shí)例,本文詳細(xì)全面的講解了文件上傳相關(guān)的需求分析及功能實(shí)現(xiàn),并同時(shí)給出了使用代碼,需要的朋友可以參考下。 PHP實(shí)現(xiàn)文件上傳與下載
    2016-10-10
  • PHP 正則表達(dá)式常用函數(shù)

    PHP 正則表達(dá)式常用函數(shù)

    前篇文章,我們復(fù)習(xí)了php的一些常用的正則表達(dá)式,本文,我們來(lái)重點(diǎn)介紹下php正則表達(dá)式的常用函數(shù),兩者相結(jié)合才可以完美使用哦??!
    2014-08-08
  • ThinkPHP數(shù)據(jù)操作方法總結(jié)

    ThinkPHP數(shù)據(jù)操作方法總結(jié)

    這篇文章主要介紹了ThinkPHP數(shù)據(jù)操作方法,以實(shí)例形式較為詳細(xì)的分析總結(jié)了ThinkPHP添加、更新、查詢及刪除數(shù)據(jù)的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-09-09

最新評(píng)論