从数据结构角度分析foreach效率比for循环高的原因
来源:互联网 发布:mac 类似梦幻西游游戏 编辑:程序博客网 时间:2024/05/20 20:45
来源:http://www.2cto.com/kf/201610/555055.html
在PHP开发过程中,我们都知道在循环的时候,foreach效率比for高,但是为什么foreach效率高呢?其实这是跟PHP变量的数据结构有关。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
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;
键(key):用于操作数据的标示,例如PHP数组中的索引,或者字符串键等等。槽(slot/bucket):哈希表中用于保存数据的一个单元,也就是数据真正存放的容器。哈希函数(hash function):将key映射(map)到数据应该存放的slot所在位置的函数。哈希冲突(hash collision):哈希函数将两个不同的key映射到同一个索引的情况。
HashTable的数据结构如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
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循环效率更高一些。
HashTable的数据结构
0 0
- 从数据结构角度分析foreach效率比for循环高的原因
- 从数据结构角度分析foreach效率比for循环高的原因
- 从数据结构角度分析foreach效率比for循环高的原因
- 源码分析foreach效率比for循环高
- 从源码角度看for循环和foreach的区别
- for和foreach循环的效率对比
- StringBuilder效率比String高的原因。
- for循环、forEach、map、filter区别及效率分析
- memcpy的内存重叠问题 + memcpy比for循环效率高
- 深入探讨array_map、foreach、for循环处理数组的效率
- 开关型直流电源比线性直流电源效率高的原因?
- Java foreach和for对不同数据结构的效率
- 作为Unity3D的脚本而言,c#中for是否真的比foreach效率更高?
- for循环嵌套效率分析
- 从spring源码角度分析循环依赖bean的组装
- for和foreach那个效率更高?原因是什么?
- 如何写for循环 效率高
- C#循环效率比较 Item6 - Prefer 'for' over 'foreach'. [Performance]
- PowerBuilder 介绍
- Linear Algebra - Lesson 24. 马尔可夫矩阵,傅里叶级数
- 戏说春秋一图穷匕见
- JAVA 入门学习之路-正则。
- R语言 牛顿-拉夫森迭代法求方程组
- 从数据结构角度分析foreach效率比for循环高的原因
- Linear Algebra - Lesson 25. 复习(二)
- nginx源码学习
- Cocos2d-x Windows环境配置
- WEB项目中图解no session问题产生的原因和解决方法
- Required MultipartFile parameter 'file' is not present
- 展望
- c#学习一:类的基本概念
- ios开发之xcode环境介绍