概念:
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遍历顺序表时消耗是一样的!