1. Lua函數(shù)支持多返回值,但并不是每次調(diào)用函數(shù)返回的全部值都會(huì)被使用。
有一條規(guī)則是只有當(dāng)函數(shù)調(diào)用是表達(dá)式最后一個(gè)元素時(shí),才會(huì)使用它的全部返回值。看代碼:
--string.find函數(shù)返回兩個(gè)值,:被查找子串的開始索引和結(jié)束索引
s,e = string.find("Lua program language","Lua")
print(s,e) --> 1 3
--如果找不到,則輸出nil和nil
s,e = string.find("Lua program language","Lub")
print(s,e) -->nil nil
--找出數(shù)組中最大的元素和其索引
function maximum(a)
local mi = 1 --最大元素索引,開始假設(shè)第一個(gè)元素就是最大元素
local m = a[mi]
for i,val in ipairs(a) do
if m < val then
mi,m = i,val
end
end
return mi,m
end
print(maximum{1,2,10,4,5,7}) --> 3 10
--返回多個(gè)值的函數(shù)只有作為表達(dá)式最有一個(gè)元素時(shí)才能使用它返回的多個(gè)值
--否則只取第一個(gè)值
--定義一個(gè)返回兩個(gè)值的函數(shù)
function foo() return "a","b" end
--foo()在表達(dá)式最后,使用了他返回的兩個(gè)值
a,b = foo() -->a b
print(a,b)
--foo()出現(xiàn)在表達(dá)式中間, 只使用了她返回的第一個(gè)值
a,b,c = foo(),"c"
print(a,b,c) -->a c nil
--使用了函數(shù)返回的兩個(gè)結(jié)果
print(foo()) -->a b
--把函數(shù)調(diào)用放在括號(hào)中間, 迫使函數(shù)只返回的一個(gè)結(jié)果
print((foo())) --> a
2. 函數(shù)支持變長(zhǎng)參數(shù):...
如果變長(zhǎng)參數(shù)中沒有nil,那么可以使用ipairs(...)來遍歷得到所有的參數(shù).
如果參數(shù)中有nil,那么就只能使用select()函數(shù)了. 因?yàn)閕pairs只能遍歷到nil處.
--變長(zhǎng)參數(shù)
--使用變長(zhǎng)參數(shù)完成對(duì)nunmber列表求和
function add(...)
local sum = 0
for i,v in ipairs(...) do
sum = sum + v
end
return sum
end
print(add{1.1,2.2,3.3,4.4,nil,6,8}) -->11 說明nil后面的6,8都沒有遍歷到
--如果變長(zhǎng)參數(shù)中故意傳入nil
--那么就要使用select函數(shù)來訪問變長(zhǎng)參數(shù)列表了.
--select得以參數(shù)如果傳入的是整數(shù)n, 返回的是第i個(gè)元素開始到最后一個(gè)元素結(jié)束的列表
--如果傳入的是"#",則返回參數(shù)列表的總長(zhǎng)度
function add2(...)
local sum = 0
local arg
for i=1,select('#',...) do
--從輸出結(jié)果可見,select(i,...) 返回的是第i個(gè)元素開始到最后一個(gè)元素結(jié)束的列表
print(select(i,...)) -->2 4 6 nil 5 8
-->4 6 nil 5 8
-->6 nil 5 8
-->nil 5 8
-->5 8
-->8
--只取列表的第一個(gè)值
arg = select(i,...)
if arg then
sum = sum + arg
end
end
return sum
end
print(add2(2,4,6,nil,5,8)) -->25 說明nil后邊的值都遍歷到了
3.closure(閉包)
我的理解是:使得內(nèi)部函數(shù)能夠調(diào)用外部函數(shù)的局部變量,而且在外部函數(shù)調(diào)用結(jié)束后仍然能使用外部函數(shù)的局部變量.而每次調(diào)用外部函數(shù)的會(huì)重新創(chuàng)建一個(gè)closure,而且以前的不會(huì)消失.這里不禁產(chǎn)生一個(gè)疑問:closure在什么時(shí)候釋放?
-- closure的特性
function newCounter()
local i = 0
return function()
i = i + 1
return i
end