1. Lua函數支持多返回值,但并不是每次調用函數返回的全部值都會被使用。
有一條規則是只有當函數調用是表達式最后一個元素時,才會使用它的全部返回值??创a:
復制代碼 代碼如下:
--string.find函數返回兩個值,:被查找子串的開始索引和結束索引
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
--找出數組中最大的元素和其索引
function maximum(a)
local mi = 1 --最大元素索引,開始假設第一個元素就是最大元素
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
--返回多個值的函數只有作為表達式最有一個元素時才能使用它返回的多個值
--否則只取第一個值
--定義一個返回兩個值的函數
function foo() return "a","b" end
--foo()在表達式最后,使用了他返回的兩個值
a,b = foo() -->a b
print(a,b)
--foo()出現在表達式中間, 只使用了她返回的第一個值
a,b,c = foo(),"c"
print(a,b,c) -->a c nil
--使用了函數返回的兩個結果
print(foo()) -->a b
--把函數調用放在括號中間, 迫使函數只返回的一個結果
print((foo())) --> a
2. 函數支持變長參數:...
如果變長參數中沒有nil,那么可以使用ipairs(...)來遍歷得到所有的參數.
如果參數中有nil,那么就只能使用select()函數了. 因為ipairs只能遍歷到nil處.
復制代碼 代碼如下:
--變長參數
--使用變長參數完成對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都沒有遍歷到
--如果變長參數中故意傳入nil
--那么就要使用select函數來訪問變長參數列表了.
--select得以參數如果傳入的是整數n, 返回的是第i個元素開始到最后一個元素結束的列表
--如果傳入的是"#",則返回參數列表的總長度
function add2(...)
local sum = 0
local arg
for i=1,select('#',...) do
--從輸出結果可見,select(i,...) 返回的是第i個元素開始到最后一個元素結束的列表
print(select(i,...)) -->2 4 6 nil 5 8
-->4 6 nil 5 8
-->6 nil 5 8
-->nil 5 8
-->5 8
-->8
--只取列表的第一個值
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(閉包)
我的理解是:使得內部函數能夠調用外部函數的局部變量,而且在外部函數調用結束后仍然能使用外部函數的局部變量.而每次調用外部函數的會重新創建一個closure,而且以前的不會消失.這里不禁產生一個疑問:closure在什么時候釋放?
復制代碼 代碼如下:
-- closure的特性
function newCounter()
local i = 0
return function()
i = i + 1
return i
end
您可能感興趣的文章:- oracle中變長數組varray,嵌套表,集合使用方法
- 淺談C++內存分配及變長數組的動態分配
- C語言可變參數函數詳解示例
- C/C++宏定義的可變參數詳細解析
- C++可變參數的實現方法
- 關于C/C++中可變參數的詳細介紹(va_list,va_start,va_arg,va_end)
- C/C++中可變參數的用法詳細解析
- C++用指針變量作為函數的參數接受數組的值的問題詳細總結
- C++可變參數的函數與模板實例分析
- C++中的變長參數深入理解