ruby元編程之method_missing的一個(gè)使用細(xì)節(jié)
我們知道頂級(jí)域,定義域的self是啥?
puts self #main
puts self.class #Object
我們知道當(dāng)一個(gè)方法被調(diào)用的時(shí)候,如果沒(méi)有對(duì)象接受,默認(rèn)就是self,如:
def tell_me_who
puts self
end
tell_me_who #main
方法調(diào)用是這樣的步驟,先查找當(dāng)前對(duì)象的所在類的實(shí)例方法存在方法與否,如果存在,調(diào)用方法,如果不存在則查看superclass,直到 BasicObject都沒(méi)找到對(duì)于方法的話,就會(huì)調(diào)用Kernel的method_missing()方法,并且報(bào)錯(cuò),如
Error:test.rb:8: undefine: undefined local variable or method `ask' for main:Object (NameError)
注意報(bào)錯(cuò)的信息,我們可以發(fā)現(xiàn),當(dāng)我們調(diào)用一個(gè)不存在的變量的時(shí)候,也是會(huì)追溯到Kernel的method_missing方法的,這里要注意咯。
驗(yàn)證:
puts self #main
puts self.class #Object
def self.method_missing(name,*arg)
puts "#{name} is not exist!"
end
puts ask #ask is not exist!
一個(gè)案例導(dǎo)致BUG:
def self.method_missing(name,*arg)
1.times do
puts method_name=name
end
puts "#{method_name} is not exist!"
end
ask #變量或者方法
意圖:讓任何未定義的變量或者方法,都打印一次
可是,這是一個(gè)死循環(huán)?看出問(wèn)題了嗎
ask被執(zhí)行,可是沒(méi)有定義ask,就會(huì)轉(zhuǎn)到method_missing,
method_name在times的block中,出了作用域了,所以又會(huì)執(zhí)行method_missing,變成了死循環(huán)。
相關(guān)文章
詳解Ruby設(shè)計(jì)模式編程中對(duì)單例模式的運(yùn)用
這篇文章主要介紹了Ruby設(shè)計(jì)模式編程中對(duì)單例模式的運(yùn)用,講到了包括對(duì)Singleton模塊的使用,需要的朋友可以參考下2016-03-03
比較不錯(cuò)的關(guān)于ruby的電子書(shū)下載地址集合
比較不錯(cuò)的關(guān)于ruby的電子書(shū)下載地址集合...2007-10-10
ruby 小腳本搞定CVS服務(wù)器更換后checkout下來(lái)的工程遷移
CVS換了新的服務(wù)器,原來(lái)的工程需要更改Server配置,這個(gè)東東手工做起來(lái) 可是個(gè)體力活,寫(xiě)了一個(gè)腳本分發(fā)下來(lái)。2008-12-12
Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例
二分查找是一種在已經(jīng)過(guò)排序的數(shù)組中搜索指定元素用的算法,這里我們就來(lái)看一下Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例:2016-07-07

