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
@f是A和B的类变量吗? 如何仅通过将其写入M?
来共享A和B之间的变量答案 0 :(得分:1)
不直接使用@@ f,而是使用class_variable_set()和class_variable_get(),可以在M中使用A,B和C的类变量。
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。
答案 1 :(得分:0)
类变量可以满足您的需求:
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
答案 2 :(得分:0)
B :: A.f将产生正确的结果