原文地址:
http://blog.csdn.net/booirror/article/details/39829259
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, ","))
阅读(1068) | 评论(0) | 转发(0) |