我想知道Ruby模块的实例变量在多个类中的行为如何“混合”它。我写了一个示例代码来测试它:#HereisamoduleIcreatedwithoneinstancevariableandtwoinstancemethods.moduleSharedVar@color='red'defchange_color(new_color)@color=new_colorenddefshow_colorputs@colorendendclassExample1includeSharedVardefinitialize(name)@name=nameendendclassExample2includ
这是我的Note的一部分类:classNoteattr_accessor:semitones,:letter,:accidentaldefinitialize(semitones,letter,accidental=:n)@semitones,@letter,@accidental=semitones,letter,accidentalenddef(other)@semitonesother.semitonesenddef==(other)@semitones==other.semitonesenddef>(other)@semitones>other.semitonesenddef在
以前有人问过与此类似的问题,但我特别询问有关使用组合作为使用模块混入的替代方法的问题。classHelperdefdo_somthingendend如果我需要“使用”一个类而不是继承它,我会简单地组合它并使用它。classMyStuffdefinitializehelper=Helper.newhelper.do_somethingendend我为什么要为此创建一个模块:moduleHelperdefdo_somethingendendclassMyStuffincludeHelperend我看到的唯一区别是,如果我使用模块,周围不会有很多Helper对象。但是我没有看到任何东西周围有
我是Ruby新手。一个简单的例子,我需要的:classAnimalabstracteat()classCat换句话说,所有扩展Animal的类都需要eat()方法。在JAVA中我只会使用抽象类,但经过一些研究后我发现很多人在Ruby中不使用它,而推荐使用mixin/modules。但是,我不明白,模块是否可以做的不仅仅是包含一个加法。确切地说,模块是否可以为类设置他们必须实现哪些方法的要求(如果是,将不胜感激)?总而言之,在这种情况下,当我想确定所有相同类型的类都有特定的方法并以自己的方式实现它们时,我应该使用什么? 最佳答案 使用
我正在查看rubymixin博客文章,它说当一个模块包含在一个类中时,它的self.included()方法被调用。我的问题是,这种行为的正式记录在哪里?我似乎无法在ruby-docs.org网站或镐上找到它。 最佳答案 虽然它不在RubyDoc上出于某种原因,included实际上已被记录。在终端中运行riModule.included提供以下内容:included(othermod)Callbackinvokedwheneverthereceiverisincludedinanothermoduleorclass.Thiss
我想根据包含此Mixin的类名在Mixin中动态生成一个类方法。这是我当前的代码:moduleMyModuleextendActiveSupport::Concern#defsome_methods#...#endmoduleClassMethods#HereiswhereI'mstuck...define_method"#{self.name.downcase}_status"do#dosomething...endendendclassMyClass但这给了我以下方法名称:MyClass.mymodule::classmethods_status在方法定义中获取基类名称是可行的(s
是否有任何干净的方法来初始化旨在用作Mixin的模块中的实例变量?例如,我有以下内容:moduleExampledefon(...)@handlers||={}#dosomethingwith@handlersenddefall(...)@all_handlers||=[]#dosomethingwith@all_handlersenddefunhandled(...)@unhandled||=[]#dosomethingwithunhandledenddefdo_something(..)@handlers||={}@unhandled||=[]@all_handlers||=[]#
我刚刚遇到了这种我不太理解的行为。moduleMdeffoo"module_foo"endendclassCdeffoo"class_foo"endincludeMendputsC.new.foo为什么C.new.foo实际上返回class_foo?我非常确定该方法应该被模块中的方法覆盖。另一件事,将"class_foo"替换为super会使C.new.foo返回`"module_foo"这实际上看起来像是在定义类实例方法之前以某种方式包含了模块。你能解释一下吗? 最佳答案 来自ProgrammingRuby关于mixin的部分:I
据说Matz说“mixins几乎可以做多重继承做的所有事情,而没有相关的缺点”(Matz的话)。首先,为什么Ruby模块包含不是“多重继承”?在我看来,模块和类之间的区别很小。当模块用作父类(superclass)时,不能实例化模块这一事实是无关紧要的。我也知道,连续的模块包含形成了一个从类向上延伸的继承链(不是树)。但是,对我来说,这不足以将它与“多重继承”区分开来,因为Python多重继承系统也“线性化”了父类(superclass)链(使用C3algorithm),只是Ruby的“线性化”过程要简单得多。那么,Ruby模块混入与Python等语言中的多重继承究竟有什么区别呢?为什
A类和B类是相同的:classA像这样用基类进行重构有什么区别:classBase与这样使用基本模块:moduleBasedeffooputs"foo"endendclassA一种方式优于另一种方式吗? 最佳答案 这两种方法之间存在根本区别,所有其他答案都缺失,那就是Rails对STI(单表继承)的实现:http://api.rubyonrails.org/classes/ActiveRecord/Base.html(找到“单表继承”部分)基本上,如果您像这样重构您的基类:classBase然后,您应该有一个名为“bases”的数据