class MyClass def one def two end end end obj = MyClass.new obj.one puts obj.method(:two).owner #==> MyClass
这里我在另一个方法中定义方法二.方法一由MyClass(obj)的实例调用.因此,当定义方法二时,self是obj.当我检查方法二的所有者时,它是MyClass
obj.instance_eval do def three end end puts obj.method(:three).owner #==> #<Class:#<MyClass:0x007f85db109010>>
在这个片段中,我在obj上执行instance_eval,因此当定义方法三时,self又是obj.但是当我检查三个人的主人时,它是obj的单身类
为什么是这样?除了self还有什么能决定方法定义的去向吗?
解决方法
这是由ruby-core贡献者yugui:
Three implicit contexts in Ruby的一篇很好的文章中解释的.基本上,有一个默认的定义上下文,它与self不同.未明确定义为单例方法的方法最终将作为默认定义上下文的实例方法.模块和类定义体更改默认定义上下文,而def不更改. instance_eval OTOH确实改变了它.