当我在顶级执行定义并且结果令人惊讶时,我正在检查Ruby中定义方法的位置:
def foo; end
singleton_class != Object # => true
self.class == Object # => true
m1 = singleton_class.instance_method :foo
# => #<UnboundMethod: Object#foo>
m2 = Object.instance_method :foo
# => #<UnboundMethod: Object#foo>
m1 == m2 # => true
似乎foo
同时在两个类中定义!有什么解释吗?
答案 0 :(得分:0)
这个问题毫无意义,真的。该方法仅在Object
中定义。当然,人们可以通过单身人士课程来达到目的,但那里没有定义:
singleton_class.instance_methods(false).grep /foo/ # => []
唉...