Ruby 1.9概要(3)類和模塊
三、類和模塊1、Module#instance_methods, #private_instance_methods, #public_instance_methods Module這三個方法都將返回方法名
的symbol組成的數組,而非過去的字符串數組。
2、Module#const_defined?, #const_get 這兩個方法都添加一個參數flag,用來決定是否將它的ancestor中的const包括在查
找鏈中,例如:
module A; X = 1; def foo; end end
module B
include A
const_defined? "X" # => true
const_defined? "X",false #uninitialized constant
const_get "X" # => 1
const_get "X",false #uninitialized constant
end
module B
include A
const_defined? "X" # => true
const_defined? "X",false #uninitialized constant
const_get "X" # => 1
const_get "X",false #uninitialized constant
end
3、Module#class_variable_defined?方法:
class X; end
X.class_variable_defined? :@@a # => false
class X; @@a = 1 end
X.class_variable_defined? :@@a # => true
class_variable_{get,set}方法:X.class_variable_defined? :@@a # => false
class X; @@a = 1 end
X.class_variable_defined? :@@a # => true
class B; self end.class_variable_set(:@@a, "foo") # => "foo"
4、Module#attr等價於Module#attr_reader:
class Test
attr:foo
def initialize
@foo=3
end
end
t=Test.new
puts t.foo #=>3
t.foo=4 #undefined method "foo="
attr:foo
def initialize
@foo=3
end
end
t=Test.new
puts t.foo #=>3
t.foo=4 #undefined method "foo="
5、接下來是一個bug fix的問題。下麵這段代碼是為了證明對象的singleton類繼承自對象的類:
class X;end; x=X.new; class << x;p self < X; end
在1.8上,這段代碼打印nil,這是不符合Ruby的對象模型的,因此在1.9運行已經可以打印正確結果true了。
如果不理解這點,參照俺過去寫的《Ruby對象模型》
6、新增Module#module_exec方法,與Object#instance_exec類似
7、綁定未綁定的方法時進行額外的子類型檢查,例如下麵的代碼:
class Foo; def foo; end end
module Bar
define_method(:foo, Foo.instance_method(:foo))
end
a=""
a.extend Bar
a.foo
module Bar
define_method(:foo, Foo.instance_method(:foo))
end
a=""
a.extend Bar
a.foo
在1.8上,這段代碼隻有當執行到a.foo的時候才報錯:"foo":bind arguments must be an instance of Foo(TypeError)
因為foo是Foo的instance method,因此調用者必須是Foo或者其子類的instance。 而在1.9中,在綁定還沒有綁定的方法的時候引入了額
外的檢查,因此上麵這段代碼不必等到a.foo調用就將報錯:
class Foo; def foo; end end
module Bar
define_method(:foo, Foo.instance_method(:foo)) #=》 in "defined_method":bind arguments must be a subclass
of Foo<TypeError>
end
module Bar
define_method(:foo, Foo.instance_method(:foo)) #=》 in "defined_method":bind arguments must be a subclass
of Foo<TypeError>
end
8、binding#eval方法,新增加的:
a=1
binding.eval("p a") => 1
binding.eval("p a") => 1
這個貌似與1.8中的:
a=1
eval("a",binding)
文章轉自莊周夢蝶 ,原文發布時間2008-10-01 eval("a",binding)
最後更新:2017-05-18 11:01:46