欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

浅析Lua中的迭代器

程序员文章站 2022-06-24 11:55:12
 迭代器是一种结构,使能够遍历所谓的集合或容器中的元素。在lua中,这些集合通常是指那些用于创建各种数据结构,如数组表。 一般对于迭代器 一个通用的迭代器提供...

 迭代器是一种结构,使能够遍历所谓的集合或容器中的元素。在lua中,这些集合通常是指那些用于创建各种数据结构,如数组表。
一般对于迭代器

一个通用的迭代器提供的键值对集合中的每个元素。下面一个简单的实例。

复制代码 代码如下:
array = {"lua", "tutorial"}

for key,value in ipairs(array)
do
   print(key, value)
end

当我们运行上面的代码之后将得到下面的输出

复制代码 代码如下:
1  lua
2  tutorial

上面的示例使用由lua中提供的默认ipairs迭代函数。

在lua中,我们使用函数来表示迭代器。基于这些迭代器的功能状态保持,有两种主要类型:

  1.     无状态的迭代器
  2.     迭代器状态

无状态的迭代器

由名字本身就可以明白,这类型的迭代器功能不保留任何状态。

现在让我们来看看使用打印n个数的平方简单的函数,来创建我们自己的迭代器的例子。

复制代码 代码如下:
function square(iteratormaxcount,currentnumber)
   if currentnumber<iteratormaxcount
   then
      currentnumber = currentnumber+1
   return currentnumber, currentnumber*currentnumber
   end
end

for i,n in square,3,0
do
   print(i,n)
end

当我们运行上面的程序,会得到下面的输出。

复制代码 代码如下:
1 1
2 4
3 9

上面的代码可以稍微进行修改,以模仿迭代器的工作方式ipairs函数。它如下所示。

复制代码 代码如下:
function square(iteratormaxcount,currentnumber)
   if currentnumber<iteratormaxcount
   then
      currentnumber = currentnumber+1
   return currentnumber, currentnumber*currentnumber
   end
end

function squares(iteratormaxcount)
   return square,iteratormaxcount,0
end 

for i,n in squares(3)
do
 print(i,n)
end

当我们运行上面的程序,会得到下面的输出。

复制代码 代码如下:
1 1
2 4
3 9

迭代器状态

迭代使用功能不保留状态,前面的例子。每次调用该函数时,它返回一个基于发送给函数的第二变量的集合的下一个元素。来保存当前元素的状态,封闭物使用。关闭保留不同职能调用变量的值。要创建一个新的闭包,我们创建了两个函数,包括封闭自己,一个工厂,创建封闭的功能。

现在让我们看看创造我们自己的迭代中,我们将使用闭包的一个例子。

复制代码 代码如下:
array = {"lua", "tutorial"}

function elementiterator (collection)
   local index = 0
   local count = #collection
   -- the closure function is returned
   return function ()
      index = index + 1
      if index <= count
      then
         -- return the current element of the iterator
         return collection[index]
      end
   end
end

for element in elementiterator(array)
do
   print(element)
end

当我们运行上面的程序,会得到下面的输出。

复制代码 代码如下:
lua
tutorial

在上面的例子中,我们可以看到,元素迭代具有另一种方法里,使用的本地外部变量索引和计数由每个函数被调用时递增索引,返回每个集合中的元素。

我们可以创建使用闭包的函数的迭代器,如上图所示,它可以返回多个元素,每一个我们通过收集循环时间。