Lua迭代器以及各种源函数的实现

范型for

范型for的格式如下所示:

Lua 复制代码
for <var-list> in <exp-list> do
    <body> 
end

var-list指变量名列表,可以为多个,exp-list指表达式列表,通常情况下只有一个值。可以更具体地写为另一种形式:

Lua 复制代码
for var_1, ..., var_n in explist(s) do block end

例如代码块中常见的for k,v in pairs(tb) do end或者for k,v in ipairs(tb) do end,都是这种范型形式,如若转换成while形式则如下:

Lua 复制代码
local func = explist
local s
while true do
    local var_1, ..., var_n = func(s)
    if var_1 == nil then
        break
    end
    block
end

源函数iter、ipairs、pairs实现

可以随意写一个简单的迭代器循环:

Lua 复制代码
function iter(a)
    local i = 0
    return function()
        i = i + 1
        return a[i]
    end
end

for n in iter({1,2,3}) do
    print(n) -- 1  2  3
end

相当于是以下代码结构:

Lua 复制代码
local iterator = iter({1,2,3})
local n = iterator()
while n do
    print(n)
    n = iterator()
end

ipairs函数只不过是上面iter内部的return a[i]改为return i,a[i]罢了。

pairs函数则是用到了next方法:

Lua 复制代码
function pairsMySelf(a)
    local key,value = next(a)
    return function()
        local oldKey,oldValue = key,value
        if value ~= nil then
            key,value = next(a,key)
        end
        return oldKey,oldValue
    end
end

local tb = {
    ["a"] = 1,
    ["b"] = 1,
    ["c"] = 1,
}
for k,v in pairsMySelf(tb) do
    print(k,v)
end
--[[print:
            a       1
            b       1
            c       1
]]--
相关推荐
APItesterCris7 分钟前
高并发场景下的挑战:1688 商品 API 的流量控制、缓存策略与异步处理方案
大数据·开发语言·数据库·缓存
yyy(十一月限定版)9 分钟前
c语言——栈和队列
java·开发语言·数据结构
feeday10 分钟前
Python 删除重复图片 优化版
开发语言·python
.格子衫.14 分钟前
JS原型链总结
开发语言·javascript·原型模式
麦麦鸡腿堡17 分钟前
Java_MySQL介绍
java·开发语言·mysql
于是我说17 分钟前
一份Python 面试常见问题清单 覆盖从初级到高级
开发语言·python·面试
shoubepatien17 分钟前
JavaWeb_Web基础
java·开发语言·前端·数据库·intellij-idea
吧啦蹦吧31 分钟前
`org.springframework.util.ClassUtils#forName
开发语言·python
CC.GG32 分钟前
【C++】红黑树
java·开发语言·c++
学IT的周星星43 分钟前
java常见面试题
java·开发语言