Posted on 2014-11-17 17:30
S.l.e!ep.¢% 閱讀(2269)
評論(2) 編輯 收藏 引用 所屬分類:
Lua
之前對closure一知半解,在網上也找不到一篇文章能把它說清楚,今天好像第一次對它有點清晰的了解 了,寫個BLOG記念一下
lua的函數是一種 First-Class Value 的東西, 到底是啥?
就是它們與傳統類型的變值沒啥區別,
可以 存到一個變量中,
可以 存到table中,
可以 作為實參傳遞給其它函數,
可以 作為其它函數的返回值.
它們還具有特定的詞法域(Lexical Scoping), 也就是說, 一個函數可以嵌套在另一個函數中, 內部的函數可以訪問外部函數中的變量.
如下面的例子:
function test(x)
??? return function (value)
??????? return value * x
??? end
end
func = test(10)
print( func(11) )
在test()中,嵌套了一個匿名函數作為返回值, 而在這個匿名函數中 可以訪問外部的 value 變量
再看另一個例子
function newCounter()
??????? local i = 0
??????? func = function()
??????????????? i = i + 1
??????????????? return i
??????? end
??????? return func
end
c = newCounter()
print(c())
print(c())
c1 = newCounter()
print(c1())
print(c1())
代碼中, 函數 func 里訪問了一個 "非局部的變量" i, 用于保存一個計數器
初步看,由于創建變量i的函數 newCounter 已經返回, 所以每次調用 func 時, 應該是超過了作用范圍
其實不然, lua 會以 closure 的概念來處理這種情況.
一個 closure 就是一個函數加上該函數所需訪問的所有"非局部的變量"
所以上例中 c1, c2 是同個函數所創建的兩個不同的 closure, 它們各自擁有局部變量i的獨立實例.
從技術上來講, lua中只有 closure, 而不存在"函數". 因為"函數"本身就是一種特殊的 closure.
后記,C++的類對象不也可以達到類似的效果?