Lua中的table浅析
Table 浅析 lua
2023-06-13 09:15:46 时间
Lua的table提供了Map的功能,实现了"关联数组",并且整数、字符串甚至nil都可以作为索引/key;table没有固定的大小。
基于table,可以表示普通数组、符号表、集合、记录、队列和其他数据结构。
而Lua也是通过table来解决模块(module)、包(package)和对象(Object)的。
例如io.read表示使用"read"来索引tableio。
在Lua中,table既不是值也不是"变量",而是对象,可以类比Java中的数组。
table是通过构造表达式的,最简单的就是{}
>a={}
>a["name"]="wyj"
>=a.name
wyj
table永远是匿名的,一个持有table的变量与table自身没有固定的关联性:
>b=a
>b.name="ljq"
>=a.name
ljq
>b=nil
>=a.name
ljq
b["name"]和b.name等价,而对于数字只能使用b["3"]的形式,同Javascript。
同其他对象一样,当没有table的引用时,Lua的垃圾回收器最终回收table。
其实Lua将全局变量存储在一个table中。
table的长度可以通过#获取(#还可以获取字符串的长度)
>table={}
>fori=1,10do
>>table[i]=i
>>end
>=#table
10
但不是所有情况都适用
>table={}
>table[3]=3
>table.name="wyj"
>=#table
0
实际上,在第一次碰到nil时,就认为是结束标志
>table={}
>table[10]=10
>=#table
0
>table[1]=1
>=#table
1
这一点,不同于Javascript的数组长度的行为。
上面提到构造表达式{},介绍一下复杂一点的构造表达式:
a={"wyj","lmy"}
a={x=10,y=20,l="s"}
但是下面的方式不正确
>a={1=3}
stdin:1:"}"expectednear"="
>a={"x"=3}
stdin:1:"}"expectednear"="
而应该这样使用:
>x={[1]=3,["name"]="www"}
>=x[1]
3
>=x.name
www
table还可以嵌套
>a={x={y=1}}
>=a.x.y
1
更复杂的方式,可以调用函数初始化
>x={math.sin(3)}
>=x[1]
0.14112000805987
另外需要特别注意的是,无label的项会自动生成整数的label
>x={1,2,[2]=3,4,5}
>=x[1]
1
>=x[2]
2
>=x[3]
4
所以,显式的label为整数的情况下要特别小心。
另外支持用;替换,
>x={x=1;y=2;"one","two"}
>xx
1
>=x[1]
one
unpack
NoteGemHorizontalLine
内置函数unpack可以提取key为1.2.3...的元素
>t={x=3,y=4,5,6,7}
>unpack(t)
>=unpack(t)
5 6 7
>a,b,c=unpack(t)--Lua支持多重赋值
>print(a,b,c)
5 6 7
>functionsum(a,b,c)
>>returna+b+c
>>end
>=sum(unpack(t))
18
相关文章
- ABAP 数据字典里数据元素(Data Element),结构(Structure)和表类型(Table Type)三者的使用辨析试读版
- ORA-25189: illegal ALTER TABLE option for an index-organized table ORACLE 报错 故障修复 远程处理
- ORA-31632: master table “string.string” not found, invalid, or inaccessible ORACLE 报错 故障修复 远程处理
- ORA-39934: Materialized view log string.string in tablespace string and master table string.string in tablespace string are not fully contained in the transportable set. ORACLE 报错 故障修复 远程处理
- SQLServer 错误 7923 Table TABLE 对象 ID O_ID。 故障 处理 修复 支持远程
- ORA-02433: cannot disable primary key – primary key not defined for table ORACLE 报错 故障修复 远程处理
- ORA-14137: Table in partially dropped state, submit DROP TABLE PURGE ORACLE 报错 故障修复 远程处理
- ORA-14756: Table is not partitioned by Interval method. ORACLE 报错 故障修复 远程处理
- Windows Azure Table storage 之 动态Table类 DynamicTableEntity详解程序员
- MySQL Status Table_locks_immediate 数据库状态作用意思及如何正确
- READ TABLE 的用法详解编程语言
- 表MySQL查看数据库Table表一步搞定(mysql查看table)
- jQuery选择表格(table)里的行和列及改变简单样式