一、方法
Ruby 的方法定義允許為參數(shù)設(shè)置默認(rèn)值,不過(guò)在帶有默認(rèn)值的參數(shù)后面不能出現(xiàn)不帶有默認(rèn)值的參數(shù)(允許 * 和 ),也就是說(shuō)下面的方法定義是不被允許的,解釋時(shí)會(huì)出現(xiàn) parse error。 還有一點(diǎn)與 C# 不同的是,方法定義不能出現(xiàn)在方法調(diào)用的后面。
# parse error
def Display(args1="proshea", args2)
end
# 允許
def Display(args1="proshea", *args2)
end
# 允許
def Display(args1="proshea", args)
end
Show()
# 出現(xiàn)在 Show 調(diào)用之后是錯(cuò)誤的
def Show
end
Ruby 也支持 C# params 這樣的參數(shù)功能, 只是 Ruby 用 * 標(biāo)識(shí)罷了。
def Display(*args)
print %Q~#{args.join("-")}~
end
# proshea-32-WinForm
Display("proshea", 32, "WinForm")
同樣的, Ruby 也有類(lèi)似于 C# delegate 的應(yīng)用,只是更簡(jiǎn)單,直接用 來(lái)表示,并且 Ruby 用一個(gè)稱(chēng)為 yield 的關(guān)鍵字來(lái)知會(huì)解釋器執(zhí)行傳入的代碼塊或者說(shuō) Proc object(過(guò)程對(duì)象?)。
1def Display(block)
2 if block_given?
3 yield(block)
4 else
5 print %Q~沒(méi)有傳入過(guò)程對(duì)象~
6 end
7end
8
9def Show()
10 print %Q~Show 方法調(diào)用~
11end
12
13# 沒(méi)有傳入過(guò)程對(duì)象
14Display()
15# 在 Display 內(nèi)部調(diào)用 Show 方法
16# 注意起始大括號(hào)仍然只能和方法名在同一行
17Display(){
18 Show()
19}
block_given? 是被定義在內(nèi)部模塊 Kernel 當(dāng)中的方法,用以表明是否傳入了 Proc object。之后,Ruby 用 yield 通知解釋器執(zhí)行傳入的 Proc。過(guò)程對(duì)象也可以帶有參數(shù),不同于普通方法的是過(guò)程對(duì)象的參數(shù)是位于一組 | | 之中??梢允褂?Proc object 的 call 方法來(lái)調(diào)用帶參數(shù)的過(guò)程對(duì)象。
1class Employee
2 def initialize(username, age, block)
3 @username, @age, @block = username, age, block
4 end
5
6 def Display(txt)
7 # 雖然 @block 是個(gè)實(shí)例變量,但在此處一定要加上大括號(hào)
8 print "#{@block.call(txt)}: #@username-#@age"
9 end
10end
11
12emp = Employee.new("proshea", 32){
13 |txt|
14 txt
15}
16emp.Display("context")
1
12345下一頁(yè)閱讀全文
您可能感興趣的文章:- Ruby 字符串處理
- RUBY文檔中心-學(xué)習(xí)開(kāi)始
- 深入理解Ruby中的block概念