0
请注意,eval会在临时范围内评估其代码。 eval可以改变已存在的实例变量的值。但是它定义的任何新的实例变量都是本地的 来调用eval并在它返回时停止存在。 (这是因为如果评估的 代码在一个块的局部变量块不会在 块外存在的身体运行。)由eval创建的新实例变量在eval退出时不会停止
- 从“Ruby编程”一书中,第二章8.3.1
irb(main):001:0> class Point
irb(main):002:1> def initialize(x,y)
irb(main):003:2> @x,@y=x,y
irb(main):004:2> end
irb(main):005:1> end
=> nil
irb(main):006:0> p=Point.new(1,2)
=> #
irb(main):007:0>
irb(main):008:0* def get_bind
irb(main):009:1> binding
irb(main):010:1> end
=> nil
irb(main):011:0> b=p.get_bind
=> #Binding:0x81915b0
irb(main):012:0>
irb(main):013:0* eval("@x",b)
=> 1
irb(main):014:0>
irb(main):015:0* eval("@x=10",b)
=> 10
irb(main):016:0> eval("@x",b)
=> 10
irb(main):017:0>
irb(main):018:0* eval("@z=2",b)
=> 2
irb(main):019:0> eval("@z",b)
=> 2
irb(main):020:0> p.instance_variables
=> [:@x, :@y, :@z]
irb(main):021:0>
irb(main):022:0*
irb(main):023:0*
实例变量 “@z” 确实不停止,为什么呢?