Lua - 表
-
介绍
表是 Lua 中唯一可用的数据结构,可以帮助我们创建不同的类型,如数组和字典。Lua 使用关联数组,它不仅可以用数字索引,还可以用除 nil 之外的字符串索引。表没有固定的大小,可以根据我们的需要增长。Lua 在所有表示中都使用表,包括包的表示。当我们访问一个方法 string.format 时,这意味着我们正在访问 string 包中可用的 format 函数。 -
表示和使用
表称为对象,它们既不是值也不是变量。Lua 使用构造函数表达式 {} 创建一个空表。要知道,保存表引用的变量与表本身之间没有固定的关系。当我们有一张表 a 带有一组元素,如果我们将其分配给 b, 两个都 a 和 b引用同一个内存。没有为 b 单独分配单独的内存。当 a 设置为 nil 时,b 仍然可以访问 table。当没有对表的引用时,Lua 中的垃圾回收会负责清理进程,以使这些未引用的内存再次被重用。下面显示了一个示例,用于解释上述表格的特征。当我们运行上面的程序时,我们将得到以下输出 - -
表格操作
有用于表操作的内置函数,它们列在下表中。序号 方法和目的 1 table.concat (table [, sep [, i [, j]]])根据给定的参数连接表中的字符串。有关详细信息,请参见示例。2 table.insert (table, [pos,] value)在表中指定位置插入一个值。3 table.maxn (table)返回最大的数字索引。4 table.remove (table [, pos])从表中删除值。5 table.sort (table [, comp])根据可选的比较器参数对表进行排序。让我们看看上述函数的一些示例。 -
表串联
我们可以使用 concat 函数连接两个表,如下所示 -当我们运行上面的程序时,我们将得到以下输出 - -
插入和删除
表中项目的插入和删除在表操作中最常见。下面进行说明。当我们运行上面的程序时,我们将得到以下输出 - -
排序表
我们经常需要按特定顺序对表格进行排序。排序函数按字母顺序对表中的元素进行排序。下面显示了一个示例。当我们运行上面的程序时,我们将得到以下输出 -