【xLua坑】使用pairs和ipairs的区别

概念:

1、table是顺序表,即 { [1] = 1, [2] = 2, ...} 或 { 1, 2, ...} 

2、table是哈希表时,即 { ["a"] = 1, ["b"] = 2, ...} 或 { a = 1, b = 2 }

pairs可遍历顺序表和哈希表,一般只遍历哈希表

ipairs只可遍历顺序表,一般顺序表只用ipairs遍历而不用pairs,因为pairs消耗比iparis大。

往往出现问题点就在于

①习惯使用ipairs时,遍历哈希表出现各种异常问题,因为iparis无法正确遍历哈希表。

②习惯使用pairs时,不会出现明显报错问题,但性能可能有所降低,如果你全部顺序表都是用pairs遍历的话。

【2021年1月30日14:43:37更新】

pairs在遍历顺序表时  和 ipairs消耗相同, pairs消耗比ipairs大 是遍历哈希表时,因为ipairs只会遍历顺序部分且遇到nil就退出

pairs源码内部是先执行了ipairs相同的代码,接着执行哈希部分数据遍历,若没有则不执行了,所以ipairs和pairs遍历顺序表时消耗是一样的!

猜你喜欢

转载自blog.csdn.net/qq_39574690/article/details/113418455