php hashtable是指散列表,是根据关键码值而直接进行访问的数据结构,也就是它可以通过把关键码值映射到表中一个位置来访问记录,从而可以加快查找的速度,其中存放记录的数组就是散列表。
新版本的hashtable
与老版本的hashtable相比改动还是挺大的
老版本的元素存储是分散的,bucket **arbuckets 里面存储的是指针 指向bucket的地址,新版的的元素存储是连续的 bucket *ardata;
老版本bucket中有4个指针 新版版中的bucket中只有一个指针,并且只有在hash碰撞的时候才会用到
少了三个指针,看下新版本的hashtable 如何做好按照插入顺序遍历和解决hash冲突
看下hashtable的定义
typedef struct _zend_array hashtable; struct _zend_array { zend_refcounted_h gc; // gc 相关 union { // 联合体 struct { zend_endian_lohi_4( zend_uchar flags, zend_uchar napplycount, zend_uchar niteratorscount, zend_uchar consistency) } v; uint32_t flags; } u; uint32_t ntablemask; // hash表的掩码 用来确定hsh bucket *ardata; // bucket数组 uint32_t *arhash; // hashtable 查找 大小为ntablemask 存放指向bucket的指针(疑问在源码定义中未看到) uint32_t nnumused; // 元素个数 包含已删除的元素 uint32_t nnumofelements; // 有效的元素个数 uint32_t ntablesize; // hash表的大小 uint32_t ninternalpointer; zend_long nnextfreeelement; dtor_func_t pdestructor; };
bucket的定义
typedef struct _bucket { zval val; zend_ulong h; //存的hash 值 用来寻找对比key zend_string *key; // 如果key是string 则存放key 如果是数字 则为空} bucket;typedef struct _zval_struct zval;struct _zval_struct { zend_value value; // value 真正的结构 union { struct { zend_endian_lohi_4( zend_uchar type, /* active type */ zend_uchar type_flags, zend_uchar const_flags, zend_uchar reserved) /* call info for ex(this) */ } v; uint32_t type_info; } u1; union { uint32_t next; // 重点关注这个 存放hash 冲突下一个元素的位置 uint32_t cache_slot; /* literal cache slot */ uint32_t lineno; /* line number (for ast nodes) */ uint32_t num_args; /* arguments number for ex(this) */ uint32_t fe_pos; /* foreach position */ uint32_t fe_iter_idx; /* foreach iterator index */ uint32_t access_flags; /* class constant access flags */ uint32_t property_guard; /* single property guard */ uint32_t extra; /* not further specified */ } u2;
结构图
推荐教程:《php》
以上就是php hashtable是什么?的详细内容。
