我不明白为什么这个工作.
module Base attr_reader :first def setup @first = 1 end end module Addon attr_reader :second def setup #super @second = 2 end end class Test include Base include Addon def initialize(num) @num = num setup end end a = Test.new(1) p a.first p a.second
基本上我有一个“基础”模块,它设置了一些东西.我也有一个插件模块,如果某个类想要包含它,它会设置一些更多的东西.
现在当我测试它,如果我没有那个超级电话,我得到
nil 2
当我有超级电话,我得到
1 2
超级实际上在这里做什么?它正在从Base模块调用setup方法,即使Base和Addon不相关.
这是我在模块的上下文中第一次使用super.以前,我一直使用超级调用与类,并认为它只是继承继承树,找到一个父类与相同的方法.
是否包括多个模块也设置某种继承树?
编辑:对于上下文,Addon模块将不会包含在没有Base模块的情况下,并且基本模块将始终包含在任何其他Addon模块之前.
解决方法
是的,当你包含模块时,它们被注入到继承链中
Test.ancestors # => [Test,Addon,Base,Object,Kernel,BasicObject]
Addon模块包含时,从Base重新定义现有的设置方法.如果您想要使用Base的版本,请使用super.