首页 > Web开发 > 详细

PHP中Array的hash函数实现

时间:2015-03-06 18:38:17      阅读:264      评论:0      收藏:0      [点我收藏+]

PHP中使用最多的非Array莫属了,那Array是如何实现的?

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

 

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

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

1.  hash = 5381设置的理由?

2.  这种step=8的循环方式是为了效率么?

 

Php代码  

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

PHP中Array的hash函数实现

原文:http://www.cnblogs.com/mingaixin/p/4318834.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!