我遇到了以下代码:
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 改变了原来的方法定义?