本文共 2469 字,大约阅读时间需要 8 分钟。
Lua允许“多重赋值”,也就是一下子将多个值赋予多个变量。每个值或每个变量之间以逗号分隔:
a, b = 10, 2*x
在多重赋值中,Lua先对等号右边的所有元素求值,然后才执行赋值。
x, y = y, x -->交换x 与y
Lua总是会将等号右边值的个数调整到与左边变量的个数相一致。规则是:若值的个数少于变量的个数,那么多余的变量会被赋为nil ;若值的个数更多的话,那么多余的值会被“静悄悄地”丢弃掉。
多重赋值一般很少使用,但在交换两个变量和用于收集函数的多个返回值时还是很有效的。例如,a, b = f(), 函数f 将返回两个值,a接收了第一个,b接收了第二个。
“尽可能地使用局部变量”是一种良好的编程风格。局部变量可以避免将一些无用的名称引入全局环境,避免搞乱了全局环境。此外,访问局部变量比访问全局变量更快。最后,一个局部变量通常会随其作用域的结束而消失,这样便使垃圾收集器可以释放其值。
i = 10 -->全局变量local j = 2 -->局部变量
在Lua中,有一种习惯写法是:
local foo = foo
这句代码创建了一个局部变量foo,并将用全部变量foo的值初始化它。如果后续其他函数改变了全局foo的值,那么可以在这里先将它的值保存起来。这种方式还可以加速在当前作用域对foo的访问。
Lua不支持switch语句,所以一连串的if then elseif else end 代码是很常见的:
if op == "+" then r = a + belseif op == "-" then r = a - belseif op == "*" r = a * belseif op == "/" r = a / belse error("invalid operation")end
对于while,Lua先测试其条件,如果条件为假,那么循环结束,不然,Lua执行循环体,并重复这一过程:
local i = 1while a[i] do print(a[i]) i = i + 1end
repeat - until 语句重复执行其循环体直到条件为真时结束。测试是在循环体之后做的,因此循环体至少会执行一次。
--打印输入的第一行不为空的内容repeat line = io.read()until line ~= ""print(line)
与其他大多数语言不同的是,在Lua中,一个声明在循环体中的局部变量的作用域包括了条件测试:
local sqr = x/2repeat sqr = (sqr + x/sqr) / 2 local error = math.abs(sqr^2 - x)until error < x/10000 -->在此仍可以访问error
for 语句有两种形式:数字型for 和泛型for。
数字型for 的语法如下:
for var=exp1, exp2, exp3 do <执行体> end 执行体>
var从exp1 变化到exp2,每次变化都以exp3作为步长递增var,并执行一次“执行体”。第三个表达式exp3 是可选的,若不指定的话,Lua会将步长默认为1.
需要注意的是:控制变量会被自动地声明为for语句的局部变量,并且仅在循环体内可见。因此,控制变量在循环结束后就不存在了。如果需要在循环结束后访问控制变量的值(通常是在break 循环时),必须将该值保存到另一变量中!
泛型for 循环通过一个迭代器(iterator)函数来遍历所有值:
--打印数组a 的所有值 --(迭代数组用ipairs)for i, v in ipairs(a) do print(v)end
Lua的基础库提供了ipairs,这是一个用于遍历数组的迭代函数。在每次循环中,i 会被赋予一个索引值,同时v 被赋予一个对应于该索引的数组元素值。
--打印table t 中所有的key --(迭代table用pairs)for k in pairs(t) do print(k)end
break 语句用于结束一个循环,它只会跳出包含它的那个内部循环(for、repeat或while),而不会改变外层的循环。在执行了break后,程序会在那个被跳出的循环之后继续执行。
return 语句用于从一个函数中返回结果,或者用于简单地结束一个函数的执行。任何函数的结尾处都有一个隐式的return。
mytable = {2, 4, k="ok", ctable={}, 6}--第一种遍历方式for i=1, #mytable do print(mytable[i])end--第二种遍历方式,与第一种方式一样都是按照当前的隐式的缩印来迭代并显示值for i,v in ipairs(mytable) do print(i,v)end--第三种遍历方式,打印所有,注意table 中索引并不完全是按照书写顺序来的for k,v in pairs(mytable) do print(k,v)end--输出:2461 22 43 61 22 43 6k okctable table: 0x7f84094097f0
s = "ok"table = {k = 10} --k 相当于一个索引table[s] = 12print(table["k"]) -->10print(table.k) -->10print(table[s]) -->12
a = 'a dshkf \\ * sd'print(string.format("%q",a) -->''a dshkf \\ * sd''--%q 表示输出全部内容
转载地址:http://plpzm.baihongyu.com/