閉包(Closure),是指未綁定到任何對象的自由代碼,閉包中的代碼與任何對象和全局變量無關(guān),只與執(zhí)行此段代碼的上下文相關(guān)。
今天我們簡要的看一下ruby中的閉包實(shí)現(xiàn)。
Ruby中的閉包實(shí)現(xiàn)有:Block,Proc,Lambada。
首先,我們來看Block。
復(fù)制代碼 代碼如下:
ary = [1,2,3,4]
ary.collect! do |a|
a*a
end
ary.each do |a|
puts a
end
這段代碼,我們使用了Array對象的block方法,將ary中的每個(gè)元素平方一把。從例子中我們可以看到block使用起來很方便,想必傳統(tǒng)的Java以及C編碼,省略掉了冗余的循環(huán),讓你更加專注業(yè)務(wù)代碼,這也是ruby的好處之一。
使用block的最大好處就是可以省略重復(fù)的冗余的無用的代碼,我們再來看一個(gè)讀文件的例子:
復(fù)制代碼 代碼如下:
#file block
File.open(__FILE__) do |f|
puts f.readlines
end
對比我們用Java代碼來讀文件,每次都很反感那個(gè)冗長的try-catch-finally。從上面的ruby代碼中我么可以看到,ruby語言給你做了處理,通過block你可以不用寫無用的系統(tǒng)代碼了。
從上面的例子我們可以看到,Ruby中的Block對開發(fā)者來說,不用再寫那些冗余無用的系統(tǒng)代碼,而是更加專注業(yè)務(wù)代碼,提升開發(fā)效率。
其次,我們再看Proc。
如果你經(jīng)常使用Block,你會發(fā)現(xiàn)一個(gè)問題:代碼中會有很多重復(fù)的Block,比如好多地方需要打印文件內(nèi)容。怎么解決呢?你第一個(gè)想到的是寫一個(gè)公共函數(shù),不錯(cuò),可以解決。但是記住你使用的是ruby語言,不要重新造輪子。Ruby提供了函數(shù)化的Block:Proc。
我們看一個(gè)簡單的Proc例子:
復(fù)制代碼 代碼如下:
#file block with Proc
p = Proc.new{|f| puts f.readlines}
File.open(__FILE__, p)
上面例子可以看到,將Block代碼定義為一個(gè)Proc對象,然后在使用Block的地方用Proc替換,這樣就做到了完美的代碼復(fù)用。
最后我們看看lambda。
Lambda是一種表達(dá)式的名稱,ruby中可以通過lambda表達(dá)式創(chuàng)建Proc對象。我們先看例子:
復(fù)制代碼 代碼如下:
#file block with Proc created with lambda
new_p = lambda{|f| puts f.readlines}
File.open(__FILE__, new_p)
上面例子中,我們使用系統(tǒng)的lambda方法創(chuàng)建了一個(gè)Proc對象,其效果與Proc.new創(chuàng)建出來的是一樣的。其實(shí)使用lambda與使用Proc.new效果是一樣的,只不過lambda是一種標(biāo)準(zhǔn)的方法,其他語言如Python也支持,因此ruby中也支持了。