相同点:都是能遍历集合(表、数组)
不同点:
ipairs: 仅仅遍历值,按照索引升序遍历,索引中断停止遍历(栗子1)。即不能返回 nil,只能返回数字 0,如果遇到 nil 则退出。它只能遍历到集合中出现的第一个不是整数的 key。(栗子2)
pairs :能遍历集合的所有元素。即 pairs 可以遍历集合中所有的 key,并且除了迭代器本身以及遍历表本身还可以返回 nil。
栗子1:
local tabFiles = {
[1] = "test2",
[6] = "test3",
[4] = "test1"
}
for k, v in ipairs(tabFiles) do
print(k, v)
end
--仅输出到索引1,因为在索引2时中断所以循环中断
1 test2
栗子2:
local tabFiles = {
[2] = "test2",
[6] = "test3",
[4] = "test1"
}
for k, v in ipairs(tabFiles) do
print(k, v)
end
--[[什么都没输出
为什么?因为控制变量初始值是按升序来遍历的,当key为1时,value为nil,此时便停止了遍历。
所有什么结果都没输出]]--
栗子3:
local tabFiles = {
[2] = "test2",
[6] = "test3",
[4] = "test1"
}
for k, v in pairs(tabFiles) do
print(k, v)
end
--输出
6 test3
4 test1
2 test2
栗子3
local tabFiles = {"alpha", "beta", [3] = "no", ["two"] = "yes"} for i,v in ipairs(tabFiles ) do --输出前三个 备注:因为第四个key不是整数
print( tabFiles [i] )
end
for i,v in pairs(tabFiles ) do
print( tabFiles [i] )
end
--输出
alpha
beta
no
alpha
beta
no
yes
因篇幅问题不能全部显示,请点此查看更多更全内容