module M
def f=(x)
@f= x
end
def f
@f
end
end
class A
extend M
end
class B < A
end
A.f= 42
puts A.f
puts B.f
这将产生
42
nil
是@fa类变量A和B? 我怎么只写成M这一份额A和B之间的变量?
module M
def f=(x)
@f= x
end
def f
@f
end
end
class A
extend M
end
class B < A
end
A.f= 42
puts A.f
puts B.f
这将产生
42
nil
是@fa类变量A和B? 我怎么只写成M这一份额A和B之间的变量?
通过不使用@@直接女,而是class_variable_set()和class_variable_get()中,A,B和C的类变量可以从内M.使用
module M
def f=(x)
class_variable_set("@@f", x)
end
def f
class_variable_get("@@f")
end
end
class A
extend M
end
class B < A
end
class C
extend M
end
A.f= 42
C.f= 23
puts A.f
puts B.f
puts C.f
这将产生
42
42
23
正如你所看到的,变量A和B,但不共享C.
B ::房颤会产生正确的结果
类变量可能会做什么您这里需要:
module M
def f=(x)
@@f= x
end
def f
@@f
end
end
class A
extend M
end
class B < A
end
A.f= 42
puts A.f
puts B.f
这将产生:
42
42
这似乎是更接近你想要的行为:
def M()
m = Module.new
m.module_eval <<-HERE
def f=(x)
@@f= x
end
def f
@@f
end
HERE
m
end
class A
extend M()
end
class B < A
end
class C
extend M()
end
A.f= 42
puts A.f
puts B.f
C.f = 23
puts C.f
puts A.f
puts B.f
生产:
42
42
23
42
42