Lua 和其他很多语言一样,函数调用时参数列表被包裹在括号中:
print('Hello World')
特别的情况是,如果函数调用时只有一个参数,并且此参数为字符串 literal(字面量)或者 table 构造器(constructor)时,包裹参数的括号可以省略:
print 'Hello World' <--> print('Hello World')
type{} <--> type({})
Lua 为面向对象的调用提供了特殊的语法:
o:foo(x) <--> o.foo(o, x)
Lua 调用的函数可能被定义在 Lua 中,也可能被定义在 C 中(Lua 标准库中的所有函数都使用 C 编写)。
函数的定义
function add(a)
local sum = 0
for i = 1, #a do
sum = sum + a[i]
end
return sum
end
print(add{1, 2, 3})
函数调用时,实参(arguments)和形参(parameters)个数可以不匹配,多余的实参会被丢弃,多余的形参值为 nil,例如:
function f(a, b) print(a, b) end
f(3) --> 3 nil
f(3, 4) --> 3 4
f(3, 4, 5) --> 3 4
函数多值返回
在 Lua 中函数可以返回多个值。例如:
function maximum(a)
local mi = 1
local m = a[mi]
for i = 1, #a do
if a[i] > m then
mi = i; m = a[i]
end
end
return m, mi
end
print(maximum{8, 10, 23, 12, 5})
在多赋值时,多余的值会被丢弃,不足时变量值为 nil:
x, y = 1 --> x == 1, y == nil
x, y = 1, 2, 3 --> x == 1, y == 2
在函数调用时形参的值处理上,在函数返回值的获取上,都遵循这个规则。例如:
function foo0() end
function foo1() return 'a' end
function foo2() return 'a', 'b' end
x, y = foo2() --> x == 'a', y == 'b'
x = foo2() --> x == 'a'
x, y, z = 10, foo2() --> x == 10, y == 'a', z == 'b'
t = { foo2() } --> {'a', 'b'}
再看一个例子:
function foo2() return 'a', 'b' end
x, y = foo2(), 20 --> x == 'a', y == 20
这里,由于函数调用不是在列表的最后一个位置,这时候函数只提供一个值。一个更有意义的例子:
function foo2() return 'a', 'b' end
print(foo2()) --> a b
print(foo2(), 1) --> a 1
如果函数调用在列表的最后一个位置,同时使用 () 包裹函数调用,这时候函数也只提供一个值:
function foo0/strong>
很多语言都支持闭包(Golang、JavaScript 等)。一个函数和其访问的外部变量组成一个闭包。看一个例子:
function newCounter()
local i = 0
return function()
i = i + 1
return i
end
end
c1 = newCounter()
print(c1()) --> 1
print(c1()) --> 2
这里的 c1 就是一个闭包(外部变量为 i),每次调用 newCounter 都会创建一个闭包(并创建一个新的变量 i):
c2 = newCounter()
print(c2()) --> 1
print(c1()) --> 3
print(c2()) --> 2
|