您的位置:首页 > 理论基础 > 数据结构算法

从数据结构角度分析foreach效率比for循环高的原因

2017-12-02 00:03 260 查看
原文链接:

https://github.com/fupengfei058/article-collection/blob/master/%E4%BB%8E%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84%E8%A7%92%E5%BA%A6%E5%88%86%E6%9E%90foreach%E6%95%88%E7%8E%87%E6%AF%94for%E5%BE%AA%E7%8E%AF%E9%AB%98%E7%9A%84%E5%8E%9F%E5%9B%A0.md

在PHP开发过程中,我们都知道在循环的时候,foreach效率比for高,但是为什么foreach效率高呢?其实这是跟PHP变量的数据结构有关。

typedef struct _zval_struct zval;

struct _zval_struct {
/* Variable information */
zvalue_value value;     /* value */
zend_uint refcount__gc;
zend_uchar type;    /* active type */
zend_uchar is_ref__gc;
};

typedef union _zvalue_value {
long lval;  /* long value */
double dval;    /* double value */
struct {
char *val;
int len;
} str;
HashTable *ht;  /* hash table value */
zend_object_value obj;
} zvalue_value;


php数组是一个HashTable。HashTable的特点:

键(key):用于操作数据的标示,例如PHP数组中的索引,或者字符串键等等。

槽(slot/bucket):哈希表中用于保存数据的一个单元,也就是数据真正存放的容器。

哈希函数(hash function):将key映射(map)到数据应该存放的slot所在位置的函数。

哈希冲突(hash collision):哈希函数将两个不同的key映射到同一个索引的情况。

HashTable的数据结构如下:

typedef struct _Bucket
{
char *key;
void *value;
struct _Bucket *next;
} Bucket;

typedef struct _HashTable
{
int size;
int elem_num;
Bucket** buckets;
} HashTable;


通过这段源码可以看出来,如果是foreach的话,可以直接通过_Bucket里的next获取到下一个值,而如果是for循环,$array[‘key’]这样子获取数据,就会需要做一次hash才会知道bucket的位置,所以foreach比for循环效率更高一些。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐