迭代器:
pairs :迭代 table,遍历表中所有的 key 和 value
ipairs :按照索引从1开始,遍历到 nil 时自动停止
tab = {"小明", "123", nil, "小刘"}
for k, v in ipairs(tab) do
print(k, v)
end
>>1 小明
>>2 123
tab = {"小明", "123", nil, "小刘"}
for k, v in pairs(tab) do
print(k, v)
end
>>1 小明
>>2 123
>>4 小刘
表(table):
- 使用字符串作为索引
tab = {b = "banana", 123}
tab.a = "apple"
tab["c"] = "Canada"
print(tab["a"])
print(tab["b"])
print(tab.c)
print(tab[1])
>> apple
>> banana
>> Canada
>> 123
- 当我们为 table a 并设置元素,然后将 a 赋值给 b,则 a 与 b 都指向同一个内存。如果 a 设置为 nil ,则 b 同样能访问 table 的元素。如果没有指定的变量指向a,Lua的垃圾回收机制会清理相对应的内存。
a = {"小明", "小强", "小基"}
print(a[1])
b = a
b[1] = "小刘"
b = nil
print(a[1])
>> 小明
>> 小刘
- 表的一些方法
table.concat():将表中的value值连接在一起,返回字符串;value有nil则报错。
tab1 = {'123', '小明', 'lua', '???'}
str = table.concat(tab1) --无缝连接
print(str)
str = table.concat(tab1, " ") --指定字符连接
print(str)
str = table.concat(tab1, ",", 1, 2) --指定字符指定位置连接
print(str)
>> 123小明lua???
>> 123 小明 lua ???
>> 123,小明
2、插入(table.insert )与移除(table.remove)
tab1 = {'123', '小明', 'lua', '???'}
table.insert(tab1, 3, "C#")
for k, v in pairs(tab1) do
print(v)
end
print("\n")
table.remove(tab1, 1)
for k, v in pairs(tab1) do
print(v)
end
>> 123
>> 小明
>> C#
>> lua
>> ???
>> 小明
>> C#
>> lua
>> ???
注:不指定位置,默认从最后面插入或移除
3、table.sort:升序排序
tab = {'a', 'A', 'z', 'f', 'd'}
table.sort(tab)
for k, v in pairs(tab) do
print(v)
end
>> A
>> a
>> d
>> f
>> z
注意:
当我们获取 table 的长度的时候无论是使用 #tab 还是 table.getn(tab) 其都会在索引中断的地方停止计数,而导致无法正确取得 table 的长度。
可以使用以下方法来代替:
function table_leng(t)
local leng=0
for k, v in pairs(t) do
leng=leng + 1
end
return leng;
end
网友评论