主頁(yè) > 知識(shí)庫(kù) > Ruby中的Proc類及Proc的類方法Proc.new的使用解析

Ruby中的Proc類及Proc的類方法Proc.new的使用解析

熱門標(biāo)簽:白銀外呼paas系統(tǒng) 滴滴外呼系統(tǒng) 百度地圖標(biāo)注自定義圖片 常德電銷平臺(tái)外呼系統(tǒng)軟件價(jià)格 高德地圖標(biāo)注客服 湖州u友防封電銷卡 電銷機(jī)器人廠商代理 地圖標(biāo)注賺錢項(xiàng)目注冊(cè) 徐州網(wǎng)絡(luò)外呼系統(tǒng)哪個(gè)好

Proc是對(duì)塊及其context(局部變量的作用域以及棧框架)進(jìn)行對(duì)象化處理之后得到的過(guò)程對(duì)象。您可以像使用無(wú)名函數(shù)那樣來(lái)使用Proc,但它不會(huì)導(dǎo)入局部變量的作用域(可以把動(dòng)態(tài)局部變量用作Proc局部變量)。

在下例中,正因?yàn)镻roc一直保持著局部變量的作用域,所以才能調(diào)用var變量。

var = 1
$foo = Proc.new { var }
var = 2

def foo
 $foo.call
end

p foo    # => 2

從生成Proc的方法中返回以后,若Proc中出現(xiàn)return或retry的話,會(huì)引發(fā)LocalJumpError異常。

def foo
 proc { return }
end

foo.call
# => in `call': return from proc-closure (LocalJumpError)

def foo
 proc { retry }
end

foo.call
# => in `call': retry from proc-closure (LocalJumpError)

若在Proc前面加上""并將其傳給一個(gè)帶塊的方法時(shí),其運(yùn)作情形類似于調(diào)用塊。但從嚴(yán)格意義上講,其間還存在以下不同。

# 沒(méi)問(wèn)題
(1..5).each { break }

# 在ruby 1.6.7, 1.8中沒(méi)問(wèn)題。在1.6.8中則發(fā)生異常
proc = Proc.new { break }
(1..5).each(proc)

# 在ruby 1.6 中是 LocalJumpError
# 在ruby 1.8 中,再次運(yùn)行each
proc = Proc.new { retry }
(1..5).each(proc)
#=> retry from proc-closure (LocalJumpError)

這正是Proc對(duì)象用作調(diào)用塊時(shí)的限制。

Proc.new
Proc.new { ... }

對(duì)塊及其context進(jìn)行對(duì)象化處理之后返回結(jié)果。

若沒(méi)有給出塊的話,就會(huì)把調(diào)用該方法的方法所帶的塊轉(zhuǎn)換為Proc對(duì)象并將其返回。

def foo
  pr = Proc.new
  pr.call(1,2,3)
end
foo {|args| p args }
# => [1, 2, 3]

Proc.new方法深入
Proc.new對(duì)塊及其context進(jìn)行對(duì)象化處理之后返回結(jié)果。

若沒(méi)有給出塊的話,就會(huì)把調(diào)用該方法的方法所帶的塊轉(zhuǎn)換為Proc對(duì)象并將其返回。

def foo
  pr = Proc.new
  pr.call(1,2,3)
end
foo {|args| p args }
# => [1, 2, 3]
這與下例相同
def foo
 yield(1,2,3)
end
foo {|args| p args }
# => [1, 2, 3]

若主調(diào)方法并沒(méi)有帶塊時(shí),則引發(fā)ArgumentError異常。

def foo
 Proc.new
end
foo
# => -:2:in `new': tried to create Proc object without a block (ArgumentError)
     from -:2:in `foo'
     from -:4

在使用Proc.new時(shí),若定義了Proc#initialize方法的話,就在對(duì)象初始化時(shí)調(diào)用該方法。除此以外,它和proc是相同的。

利用 Proc.new 方法,或者對(duì) proc 方法指定塊,都可以創(chuàng)建代表塊的 Proc 對(duì)象。

通過(guò)調(diào)用 Proc#call 方法執(zhí)行塊。調(diào)用 Proc#call 方法時(shí)的參數(shù)會(huì)作為塊變量,塊中最后一個(gè)表達(dá)式的值則為 Proc#call 的返回值。Proc#call 還有一個(gè)名稱叫 Proc#[]。

# 判斷西歷的年是否為閏年的處理
leap = Proc.new do |year|
 year % 4 == 0  year % 100 != 0 || year % 400 ==0
end
 
p leap.call(2000)  #=> true
p leap[2013]     #=> false
p leap[2016]     #=> true

將塊變量設(shè)置為 |* 數(shù)組 | 的形式后,就可以像方法參數(shù)一樣,以數(shù)組的形式接收可變數(shù)量的參數(shù)。

double = Proc.new do |*args|
 args.map{|i| i * 2 }  # 所有元素乘兩倍
end
 
p double.call(1, 2, 3)  #=> [2, 3, 4]
p double[2, 3, 4]     #=> [4, 6, 8]

除此以外,定義普通方法時(shí)可使用的參數(shù)形式,如默認(rèn)參數(shù)、關(guān)鍵字參數(shù)等,幾乎都可以被用于塊變量的定義,并被指定給 Proc#call 方法。

您可能感興趣的文章:
  • 詳解Ruby中的單件方法和單件類
  • Ruby面向?qū)ο缶幊讨蓄惻c方法的基礎(chǔ)學(xué)習(xí)
  • Ruby類實(shí)例變量、類實(shí)例方法和類變量、類方法的區(qū)別
  • Ruby面向?qū)ο缶幊讨蓄惖姆椒ㄅc類的擴(kuò)展

標(biāo)簽:梧州 永州 張家界 三沙 遼寧 普洱 公主嶺 荊門

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Ruby中的Proc類及Proc的類方法Proc.new的使用解析》,本文關(guān)鍵詞  Ruby,中的,Proc,類及,的,類,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Ruby中的Proc類及Proc的類方法Proc.new的使用解析》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Ruby中的Proc類及Proc的類方法Proc.new的使用解析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章