标准库提供了集中迭代器,包括迭代文件每行的(io.lines),迭代table元素的(pairs),迭代数组元素的(ipairs),迭代字符串中单词的
(string.gmatch)等等。LUA手册中对与pairs,ipairs解释如下:
ipairs(t)
Returns three values: an iterator function, the table t, and 0, so that the construction
for i,v in ipairs(t) do body end
will iterate over the pairs (1,t[1]), (2,t[2]), ···, up to the first integer key absent from the table.
pairs(t)
Returns three values: the next function, the table t, and nil, so that the construction
for k,v in pairs(t) do body end
will iterate over all key–value pairs of table t.
See function next for the caveats of modifying the table during its traversal.
这样就可以看出 ipairs以及pairs 的不同。
pairs遍历表中全部key,value
ipairs从下标为1开始遍历,然后下标累加1,如果某个下标元素不存在就终止遍历。这就导致如果下标不连续或者不是从1开始的表就会中断或者遍历不到元素
下面举个例子吧!
eg:
local tabFiles = {
[3] = "test2",
[6] = "test3",
[4] = "test1"
}
for k, v in ipairs(tabFiles) do
print(k, v)
end
猜测它的输出结果是什么呢?
根据刚才的分析,它在 ipairs(tabFiles) 遍历中,当key=1时候value就是nil,所以直接跳出循环不输出任何值。
>lua -e "io.stdout:setvbuf 'no'" "Test.lua"
>Exit code: 0
那么,如果是
for k, v in pairs(tabFiles) do
print(k, v)
end
>lua -e "io.stdout:setvbuf 'no'" "Test.lua"
1 test1
>Exit code: 0
--
[示例1.]
--
local tt
=
{
[1] = "test3",
[4] = "test4",
[5] = "test5"
}

for
i,v
in
pairs(tt)
do
--
输出
"
test4
"
"
test3
"
"
test5
"
print( tt[i] )
end
for
i,v
in
ipairs(tt)
do
--
输出
"
test3
"
k
=
2时断开
print( tt[i] )
end




--
[[示例2.]]
--
tbl
=
{"alpha", "beta", [3] = "uno", ["two"] = "dos"}

for
i,v
in
ipairs(tbl)
do
--
输出前三个
print( tbl[i] )
end
for
i,v
in
pairs(tbl)
do
--
全部输出
print( tbl[i] )
end
1511

被折叠的 条评论
为什么被折叠?



