Lua - 表
介绍
表是 Lua 中唯一可用的数据结构,可以帮助我们创建不同的类型,例如数组和字典。Lua 使用关联数组,它不仅可以用数字索引,还可以用除 nil 之外的字符串索引。表没有固定的大小,可以根据我们的需要进行增长。
Lua 在所有表示中都使用表,包括包的表示。当我们访问 string.format 方法时,这意味着我们正在访问 string 包中可用的 format 函数。
表示和使用
表称为对象,它们既不是值也不是变量。Lua 使用构造函数表达式 {} 创建一个空表。应该知道,保存表引用的变量与表本身之间没有固定的关系。
--sample table initialization mytable = {} --simple table value assignment mytable[1]= "Lua" --removing reference mytable = nil -- lua garbage collection will take care of releasing memory
当我们有一个包含一组元素的表a并将其分配给b时,a和b都引用相同的内存。没有为 b 单独分配单独的内存。当a设置为nil时,b仍然可以访问表。当没有对表的引用时,Lua 中的垃圾收集会负责清理过程,以使这些未引用的内存再次被重用。
下面用一个例子来解释上述表格的特点。
-- Simple empty table mytable = {} print("Type of mytable is ",type(mytable)) mytable[1]= "Lua" mytable["wow"] = "Tutorial" print("mytable Element at index 1 is ", mytable[1]) print("mytable Element at index wow is ", mytable["wow"]) -- alternatetable and mytable refers to same table alternatetable = mytable print("alternatetable Element at index 1 is ", alternatetable[1]) print("alternatetable Element at index wow is ", alternatetable["wow"]) alternatetable["wow"] = "I changed it" print("mytable Element at index wow is ", mytable["wow"]) -- only variable released and and not table alternatetable = nil print("alternatetable is ", alternatetable) -- mytable is still accessible print("mytable Element at index wow is ", mytable["wow"]) mytable = nil print("mytable is ", mytable)
当我们运行上面的程序时,我们将得到以下输出 -
Type of mytable is table mytable Element at index 1 is Lua mytable Element at index wow is Tutorial alternatetable Element at index 1 is Lua alternatetable Element at index wow is Tutorial mytable Element at index wow is I changed it alternatetable is nil mytable Element at index wow is I changed it mytable is nil
表操作
有用于表操作的内置函数,下表列出了它们。
先生。 | 方法与目的 |
---|---|
1 | table.concat(表[,sep[,i[,j]]]) 根据给定的参数连接表中的字符串。详细信息请参见示例。 |
2 | table.insert(表,[pos,]值) 将值插入到表中的指定位置。 |
3 | 表.maxn(表) 返回最大的数字索引。 |
4 | table.remove(表[, pos]) 从表中删除该值。 |
5 | table.sort(表[,comp]) 根据可选的比较器参数对表进行排序。 |
让我们看一下上述函数的一些示例。
表串联
我们可以使用 concat 函数连接两个表,如下所示 -
fruits = {"banana","orange","apple"} -- returns concatenated string of table print("Concatenated string ",table.concat(fruits)) --concatenate with a character print("Concatenated string ",table.concat(fruits,", ")) --concatenate fruits based on index print("Concatenated string ",table.concat(fruits,", ", 2,3))
当我们运行上面的程序时,我们将得到以下输出 -
Concatenated string bananaorangeapple Concatenated string banana, orange, apple Concatenated string orange, apple
插入和删除
在表操作中,插入和删除表中的项目是最常见的。下面对此进行解释。
fruits = {"banana","orange","apple"} -- insert a fruit at the end table.insert(fruits,"mango") print("Fruit at index 4 is ",fruits[4]) --insert fruit at index 2 table.insert(fruits,2,"grapes") print("Fruit at index 2 is ",fruits[2]) print("The maximum elements in table is",table.maxn(fruits)) print("The last element is",fruits[5]) table.remove(fruits) print("The previous last element is",fruits[5])
当我们运行上面的程序时,我们将得到以下输出 -
Fruit at index 4 is mango Fruit at index 2 is grapes The maximum elements in table is 5 The last element is mango The previous last element is nil
排序表
我们经常需要按特定顺序对表进行排序。排序函数按字母顺序对表中的元素进行排序。下面显示了一个示例。
fruits = {"banana","orange","apple","grapes"} for k,v in ipairs(fruits) do print(k,v) end table.sort(fruits) print("sorted table") for k,v in ipairs(fruits) do print(k,v) end
当我们运行上面的程序时,我们将得到以下输出 -
1 banana 2 orange 3 apple 4 grapes sorted table 1 apple 2 banana 3 grapes 4 orange