php数组是一个hash table。
    hash table特点:

    • 键(key):用于操作数据的标示,例如PHP数组中的索引,或者字符串键等等。
    • 槽(slot/bucket):哈希表中用于保存数据的一个单元,也就是数据真正存放的容器。
    • 哈希函数(hash function):将key映射(map)到数据应该存放的slot所在位置的函数。
    • 哈希冲突(hash collision):哈希函数将两个不同的key映射到同一个索引的情况。

    hash table 数据结构:

    1. typedef struct _Bucket
    2. {
    3. char *key;
    4. void *value;
    5. struct _Bucket *next;
    6. } Bucket;
    7. typedef struct _HashTable
    8. {
    9. int size;
    10. int elem_num;
    11. Bucket** buckets;
    12. } HashTable;

    如果是foreach的话,可以直接通过_Bucket里的next获取到下一个值,而如果是for循环,$array[‘key’]这样子获取数据,就会需要做一次hash才会知道bucket的位置,所以foreach比for循环效率更高一些。