這篇文章主要介紹了ruby元編程之method_missing的一個使用細節,本文介紹在使用method_missing時造成死迴圈的一個現象,需要的朋友可以參考下
我們知道頂級域,定義域的self是啥?
代碼如下:
puts self #main
puts self.class #Object
我們知道當一個方法被調用的時候,如果沒有對象接受,預設就是self,如:
代碼如下:
def tell_me_who
puts self
end
tell_me_who #main
方法調用是這樣的步驟,先尋找當前對象的所在類的執行個體方法存在方法與否,如果存在,調用方法,如果不存在則查看superclass,直到 BasicObject都沒找到對於方法的話,就會調用Kernel的method_missing()方法,並且報錯,如
代碼如下:
Error:test.rb:8: undefine: undefined local variable or method `ask' for main:Object (NameError)
注意報錯的資訊,我們可以發現,當我們調用一個不存在的變數的時候,也是會追溯到Kernel的method_missing方法的,這裡要注意咯。
驗證:
代碼如下:
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!
一個案例導致BUG:
代碼如下:
def self.method_missing(name,*arg)
1.times do
puts method_name=name
end
puts "#{method_name} is not exist!"
end
ask #變數或者方法
意圖:讓任何未定義的變數或者方法,都列印一次
可是,這是一個死迴圈?看出問題了嗎
ask被執行,可是沒有定義ask,就會轉到method_missing,
method_name在times的block中,出了範圍了,所以又會執行method_missing,變成了死迴圈。