5

我遇到了以下代码:

  class MethodLogger
    def log_method((klass,method_name)
      klass.class_eval do
        alias_method "#{method_name}_original" method_name
        define_method method_name do
          puts "#{Time.now}: Called #{method_name}"
          send "#{method_name}_original"
        end
      end
    end
  end


class Tweet
 def say_hi
  puts "Hi"
 end
end

logger =MethodLogger.new
logger.log_method(Tweet,:say_hi)

这给出了输出

2012-09-11 12:54:09 -400: 叫 say_hi

那么,define_method :say_hi 如何覆盖原始方法 :say_hi 呢?还是 define_method 改变了原来的方法定义?

4

1 回答 1

6

如果你多次定义一个方法,所有后面的定义都会简单地覆盖旧的。只能有一个同名的方法。

于 2013-05-29T11:08:54.720 回答