table是Lua的一种数据结构用来帮助我们创建不同的数据类型,如:数字、字典等。
Lua table 使用关联型数组,你可以使用任意类型的值来作数组的索引,但这个值不能是nil。
Lua table是不固定大小的,你可以根据自己需要进行扩容。
Lua也是通过table来解决模块(module)、包(package)和对象(Object)的。
table(表)的构造
构造器是创建和初始化表的表达式。表是Lua特有的功能强大的东西。最简单的构造函数是{},用来创建一个空表。可以直接初始化数组。
-- 初始化表mytable = {}-- 指定值mytable[1]= "Lua"-- 移除引用mytable = nil-- lua 垃圾回收会释放内存
当我们为 table a 并设置元素,然后将 a 赋值给 b,则 a 与 b 都指向同一个内存。如果 a 设置为 nil ,则 b 同样能访问 table 的元素。如果没有指定的变量指向a,Lua的垃圾回收机制会清理相对应的内存。
以下实例演示了以上的描述情况:
-- 简单的 tablemytable = {}print("mytable 的类型是 ",type(mytable))mytable[1]= "Lua"mytable["wow"] = "修改前"print("mytable 索引为 1 的元素是 ", mytable[1])print("mytable 索引为 wow 的元素是 ", mytable["wow"])-- alternatetable和mytable的是指同一个 tablealternatetable = mytableprint("alternatetable 索引为 1 的元素是 ", alternatetable[1])print("mytable 索引为 wow 的元素是 ", alternatetable["wow"])alternatetable["wow"] = "修改后"print("mytable 索引为 wow 的元素是 ", mytable["wow"])-- 释放变量alternatetable = nilprint("alternatetable 是 ", alternatetable)-- mytable 仍然可以访问print("mytable 索引为 wow 的元素是 ", mytable["wow"])mytable = nilprint("mytable 是 ", mytable)
以上代码执行结果为:
mytable 的类型是 tablemytable 索引为 1 的元素是 Luamytable 索引为 wow 的元素是 修改前alternatetable 索引为 1 的元素是 Luamytable 索引为 wow 的元素是 修改前mytable 索引为 wow 的元素是 修改后alternatetable 是 nilmytable 索引为 wow 的元素是 修改后mytable 是 nil
Table 操作
以下列出了 Table 操作常用的方法:
Table 连接
fruits = {"banana","orange","apple"}-- 返回 table 连接后的字符串print("连接后的字符串 ",table.concat(fruits))-- 指定连接字符print("连接后的字符串 ",table.concat(fruits,", "))-- 指定索引来连接 tableprint("连接后的字符串 ",table.concat(fruits,", ", 2,3))
执行结果:
连接后的字符串 bananaorangeapple连接后的字符串 banana, orange, apple连接后的字符串 orange, apple
插入和移除
fruits = {"banana","orange","apple"}-- 在末尾插入table.insert(fruits,"mango")print("索引为 4 的元素为 ",fruits[4])-- 在索引为 2 的键处插入table.insert(fruits,2,"grapes")print("索引为 2 的元素为 ",fruits[2])print("最后一个元素为 ",fruits[5])table.remove(fruits)print("移除后最后一个元素为 ",fruits[5])
执行以上代码输出结果为:
索引为 4 的元素为 mango索引为 2 的元素为 grapes最后一个元素为 mango移除后最后一个元素为 nil
Table 排序
fruits = {"banana","orange","apple","grapes"}print("排序前")for k,v in ipairs(fruits) doprint(k,v)endtable.sort(fruits)print("排序后")for k,v in ipairs(fruits) doprint(k,v)end
执行以上代码输出结果为:
排序前1 banana2 orange3 apple4 grapes排序后1 apple2 banana3 grapes4 orange
Table 最大值
function table_maxn(t)local mn=nil;for k, v in pairs(t) doif(mn==nil) thenmn=vendif mn < v thenmn = vendendreturn mnendtbl = {[1] = 2, [2] = 6, [3] = 34, [26] =5}print("tbl 最大值:", table_maxn(tbl))print("tbl 长度 ", #tbl)
执行以上代码输出结果为:
tbl 最大值: 34tbl 长度 3
注意:当我们获取 table 的长度的时候无论是使用 # 还是 table.getn 其都会在索引中断的地方停止计数,而导致无法正确取得 table 的长度。
可以使用以下方法来代替:
function table_leng(t)local leng=0for k, v in pairs(t) doleng=leng+1endreturn leng;end
table 去重
function table.unique(t, bArray)local check = {}local n = {}local idx = 1for k, v in pairs(t) doif not check[v] thenif bArray thenn[idx] = vidx = idx + 1elsen[k] = vendcheck[v] = trueendendreturn nend

