我有两个文件,一个包含模块ToMix
:
module ToMix
@module_var = "modulevar"
def self.mix_function
puts "mix_function SELF: #{@module_var}"
end
def mix_function
puts "mix_function: #{@module_var}"
end
class MixClass
attr_accessor :mixclassvar
def initialize(value)
@mixclassvar = value
end
end
end
我想混合到另一个文件中的类TestInclude
:
class TestInclude
require "ToMixFile"
include ToMix
end
有人可以解释为什么实例变量@module_var
和方法self.mix_function
,mix_function
未定义?我该如何定义它们?
t2 = TestInclude.new()
t2.mix_function # => error undefined (exected call to mix_function)
t2.module_var = "test set module_var" # => error undefined
TestInclude.mix_function # => error undefined (expected call to self.mix_function)
TestInclude.method_defined? :mix_function # => false
答案 0 :(得分:3)
模块为事物添加功能; attr_accessor
添加了与变量交互的函数。
module ToMix
@module_var = "module_var"
attr_accessor :mixed_var
def initialize
@mixed_var = "mixed_var"
end
def mix_function
puts "mix_function: #{@mixed_var}"
end
def self.module_function
@module_var
end
end
class Mixed
include ToMix
end
Mixed.new.mixed_var
值得注意的是,
"".extend(ToMix).mixed_var == nil # no error, but no value, interesting!
但
(a = "".extend(ToMix)).mixed_var = "interesting"
a.mixed_var == "interesting"
和
ToMix.module_function == "module_var"
https://stackoverflow.com/a/151774/171916 http://www.natontesting.com/2009/09/28/accessing-instance-variables-declared-in-ruby-modules/ How to dynamically alter inheritance in Ruby
编辑:如果我错了,那些比我更聪明的人应该纠正我,但模块和类定义本身就是对象。因此,在模块定义中定义@var
会将var添加到模块对象本身
编辑:那些比我更纠正我的人:虽然类和模块定义的行为类似于单身,但它们本身并不是对象。您可以将方法之外的def self.bacon
和@var
视为c ++静态方法和变量,但即使您在实例中,它们也可以/仅/可以像静态一样访问。