正如其他答案所说,Lua中的字符串连接运算符是两个点。
你简单的例子是这样写的:
filename = "checkbook"
filename = filename .. ".tmp"
但是,需要注意的一个警告。由于Lua中的字符串是不可变的,每个连接都会创建一个新的字符串对象,并将源字符串中的数据复制到它。这使得连续连接到单个字符串的性能非常差。
的的Lua成语对于这种情况是这样的:
function listvalues(s)
local t = { }
for k,v in ipairs(s) do
t[#t+1] = tostring(v)
end
return table.concat(t,"\n")
end
通过收集字符串数组t
要连接,标准库例程table.concat
可以用来连接它们加起来(连同每对之间的分隔符字符串)而不需要不必要的字符串复制
更新:我刚刚注意到我最初使用pairs()
而不是ipairs()
写了上面的代码片段。
正如最初所写,功能listvalues()
确实会从传入的表中产生每个值,但不会以稳定或可预测的顺序产生。另一方面,它将包括在1
到#s
范围内谁的密钥不是正整数的值。这就是pairs()
所做的:它产生存储在表中的每一个(键,值)对。
在大多数情况下,如果您使用类似listvaluas()
的东西,您会有兴趣保留订单。因此,编写为listvalues{13, 42, 17, 4}
的调用将按照该顺序生成包含这些值的字符串。但是,pairs()
不会这样做,它将按照某种顺序逐项列出,这取决于表数据结构的底层实现。众所周知,订单不仅取决于按键,还取决于按键的插入顺序和其他按键的移除顺序。
当然ipairs()
也不是一个完美的答案。它仅列举形成“序列”的表格的那些值。也就是说,那些键的值形成了从1到一些上限的连续块,这通常也是由运算符返回的值。 (在很多情况下,函数ipairs()
本身可以更好地被更简单的for
循环代替,循环的计数从1
到#s
。这是Lua 5.2和LuaJIT推荐的做法,其中简单的for
循环可以比迭代器ipairs()
更有效地实现)
如果pairs()
确实是正确的方法,那么通常情况下,您希望同时打印键和值。这通过使数据自我描述来减少对订单的担忧。当然,由于任何Lua类型(nil
和浮点数NaN
除外)都可以用作关键字(并且NaN
也可以作为值存储),因此找到字符串表示形式作为练习留给学生。不要忘记树木和更复杂的表格结构。