欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ruby元編程之method_missing的一個使用細節(jié)

 更新時間:2015年05月26日 09:18:54   投稿:junjie  
這篇文章主要介紹了ruby元編程之method_missing的一個使用細節(jié),本文介紹在使用method_missing時造成死循環(huán)的一個現(xiàn)象,需要的朋友可以參考下

我們知道頂級域,定義域的self是啥?

復(fù)制代碼 代碼如下:

puts self    #main
puts self.class #Object

我們知道當(dāng)一個方法被調(diào)用的時候,如果沒有對象接受,默認就是self,如:
復(fù)制代碼 代碼如下:

def tell_me_who
    puts self
end
tell_me_who  #main

 方法調(diào)用是這樣的步驟,先查找當(dāng)前對象的所在類的實例方法存在方法與否,如果存在,調(diào)用方法,如果不存在則查看superclass,直到 BasicObject都沒找到對于方法的話,就會調(diào)用Kernel的method_missing()方法,并且報錯,如
復(fù)制代碼 代碼如下:

Error:test.rb:8: undefine: undefined local variable or method `ask' for main:Object (NameError)

 注意報錯的信息,我們可以發(fā)現(xiàn),當(dāng)我們調(diào)用一個不存在的變量的時候,也是會追溯到Kernel的method_missing方法的,這里要注意咯。

驗證:

復(fù)制代碼 代碼如下:

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!

 一個案例導(dǎo)致BUG:
復(fù)制代碼 代碼如下:

def self.method_missing(name,*arg)
    1.times do
        puts method_name=name
    end
    puts "#{method_name} is not exist!"
end

ask #變量或者方法

意圖:讓任何未定義的變量或者方法,都打印一次
可是,這是一個死循環(huán)?看出問題了嗎
ask被執(zhí)行,可是沒有定義ask,就會轉(zhuǎn)到method_missing,
method_name在times的block中,出了作用域了,所以又會執(zhí)行method_missing,變成了死循環(huán)。

相關(guān)文章

最新評論