加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

lua的table库中常用的函数

发布时间:2020-12-14 22:06:30 所属栏目:大数据 来源:网络整理
导读:lua提供了一些辅助函数来操作table。例如,从list中insert和remove元素,对array的元素进行sort,或者concatenate数组中的所有strings。下面就详细地讲解这些方法。 insert and remove table.insert将一个元素插入到指定位置,例如: t = {1,2,3} table.inse
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,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,","))

(完)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读