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时,ab都引用相同的内存。没有为 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