lua提供了一些辅助函数来操作table。

比如,从list中insert和remove元素,对array的元素进行sort。或者concatenate数组中的全部strings。以下就具体地解说这些方法。





insert and remove


table.insert将一个元素插入到指定位置。比如:

t = {1, 2, 3}


table.insert(t, 1, 4}


t的结果将是{4, 1, 2, 3}


insert的第二个參数是能够省略的。这样就会插入到数组的最后,从而不必移动其它元素。相同地。table.remove是从数组中移除(并返回)一个元素,table.remove(t,1)将移除t中下标是1的元素,假设不指定移除位置,则移除最后一个。




通过insert,remove方法,就能非常直接的地实现stacks。queues, double queues. push操作就相当于table.insert(t, x), 而pop操作就相当于table.remove(t)。比如定义一个栈:

stack = {}


function stack:push(x)


     table.insert(self, x)


end




function stack:pop()


     table.remove(self)


end




sort


还有一个实用的函数是sort,对数组进行排序,假设没有提供排序函数,默认是<操作。

人们范的普遍的错误是尝试对table的key进行排序。

在table里,全部key组成个集合,绝壁没有不论什么顺序。

假设你要对他们排序。首先要将他们复制到一个数组里。然后在进行sort。假如我们有一个table,想要以排序后的key的顺序进行迭代,我们就能够写过这种迭代器:


function pairsByKeys(t, f)


     local a = {}


     for k in pairs(t) do a[#a+1] = k end


     table.sort(a, f)


     local i = 0


     return function()


          i = i + 1


          return a[i], t[a[i]]


     end


end




concatenation


给定的table,全部的元素是string或是number,将返回table[i]..sep..table[i+1] ··· sep..table[j],分隔符默认是空字符串。i默认是1, j默认是表的长度。假设i > j, 则返回空字符串。比如:




spring = {"春林渐盛", "春水初生", "春风十里不如你"}

print(table.concat(spring, ","))




(完)