程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> ruby元編程之method_missing的一個使用細節

ruby元編程之method_missing的一個使用細節

編輯:更多關於編程

       這篇文章主要介紹了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,變成了死循環。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved