http://blackanger.blog.51cto.com/140924/84057/
class_eval和module_eval方法一样, 都是为一个class增加method的。 可以接string和block为参数。 此方法是Ruby的动态特性之一。
我真没想到Matz还到ruby-forum里去混, 姑且认为是Matz本人吧,他给出的答案是:
这有个有意思的例子更加说明了这一点:
关键点是, #{y}是作为string的一部分传给了class_eval. 此时已经是puts first了。 而不是在call hello方法的时候去找y
class Thing
end
a = %q{def hello() "Hello there!" end}
Thing.module_eval(a)
puts Thing.new.hello()
=> Hello there!
end
a = %q{def hello() "Hello there!" end}
Thing.module_eval(a)
puts Thing.new.hello()
=> Hello there!
我真没想到Matz还到ruby-forum里去混, 姑且认为是Matz本人吧,他给出的答案是:
用#{y}是在compile time 的时候已经把y的值传给了class_eval.
在运行时, puts “#{y}” 已经变成了 puts “another hi”
而变量y,则因为作用域的不同,外部定义的局部变量y是class_eval无法收到的。
在运行时, puts “#{y}” 已经变成了 puts “another hi”
而变量y,则因为作用域的不同,外部定义的局部变量y是class_eval无法收到的。
这有个有意思的例子更加说明了这一点:
class T
def first
"hello"
end
def second
"chunky bacon"
end
end
y = "first"
T.class_eval <<-END
def hello
puts #{y}
end
END
T.new.hello
=>prints "hello"
def first
"hello"
end
def second
"chunky bacon"
end
end
y = "first"
T.class_eval <<-END
def hello
puts #{y}
end
END
T.new.hello
=>prints "hello"
关键点是, #{y}是作为string的一部分传给了class_eval. 此时已经是puts first了。 而不是在call hello方法的时候去找y
本文出自 “{ :Alex Space => &..” 博客,请务必保留此出处http://blackanger.blog.51cto.com/140924/84057