PHP的数组结构是用哈希表实现的

今天回顾学习了PHP中变量实现的方法,在浏览其源码是发现在PHP中所有的数据类型通过一个union存储。php语言是弱类型语言,其实现中通过记录变量的类型和值来实现其管理。

PHP中使用最多的非Array莫属了,那Array是如何实现的?在PHP内部Array通过一个hashtable来实现,其中使用链接法解决hash冲突的问题,这样最坏情况下,查找Array元素的复杂度为O(N),最好则为1.

而其计算字符串hash值的方法如下,将源码摘出来以供查备:

01 static inline ulong zend_inline_hash_func(const char *arKey, uint nKeyLength)
02 {
03     register ulong hash = 5381;                                                   //此处初始值的设置有什么玄机么?
04     /* variant with the hash unrolled eight times */
05     for (; nKeyLength >= 8; nKeyLength -= 8) {                         //这种step=8的方式是为何?
06         hash = ((hash << 5) + hash) + *arKey++;
07         hash = ((hash << 5) + hash) + *arKey++;
08         hash = ((hash << 5) + hash) + *arKey++;
09         hash = ((hash << 5) + hash) + *arKey++;                         //比直接*33要快
10         hash = ((hash << 5) + hash) + *arKey++;
11         hash = ((hash << 5) + hash) + *arKey++;
12         hash = ((hash << 5) + hash) + *arKey++;
13         hash = ((hash << 5) + hash) + *arKey++;
14     }  
15     switch (nKeyLength) {
16         case 7: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough... */                             //此处是将剩余的字符hash
17         case 6: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough... */
18         case 5: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough... */
19         case 4: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough... */
20         case 3: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough... */
21         case 2: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough... */                    
22         case 1: hash = ((hash << 5) + hash) + *arKey++; break;
23         case 0: break;
24 EMPTY_SWITCH_DEFAULT_CASE()
25     }  
26     return hash;//返回hash值
27 }

ps:对于以下函数,仍有两点不明:

  1. hash = 5381设置的理由?
  2. 这种step=8的循环方式是为了效率么?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值