--迭代器是一种可以便利一种集合中所有元素得机制
--lua中,迭代器表示为函数,每调用一次函数,即返回集合中得下一个元素
--主要是根据闭合函数来实现得:闭合函数:一个函数加上该函数所需要访问得所有“非全局变量“
--迭代器内部实现
function DieDai(t)
local i=0;
return function()
i=i+1
return t[i]
end
end
--使用方式1
t={"11","22","3","5333"}
local it=DieDai(t)
while true do
local value=it()
if value==nil then
break
end
print(value)
end
print("-------------------------")
--使用方式2
for value in DieDai(t) do
print(value)
end
print("-------------------------")
--返回两个值得迭代器
function DieDai2(t)
local i=0;
return function()
i=i+1
if i>#t then
return nil;
end
return i,t[i];
end
end
for value1,value2 in DieDai2(t) do
print(value1..value2)
end
pairs 和 ipairs区别
同:都是能遍历集合(表、数组)
异:ipairs 仅仅遍历值,按照索引升序遍历,索引中断停止遍历。即不能返回 nil,只能返回数字 0,如果遇到 nil 则退出。它只能遍历到集合中出现的第一个不是整数的 key。
pairs 能遍历集合的所有元素。即 pairs 可以遍历集合中所有的 key,并且除了迭代器本身以及遍历表本身还可以返回 nil。