我知道如何添加类方法和类行为usingself(eigenclass).但是,在阅读somesourcecode时,我看到了另一种用法:classLetterAvatarclass这是如何运作的?它有什么作用,什么时候应该使用它?什么是(可能更被认可的)替代方式来写这个? 最佳答案 我认为他们这样做是因为他们在其他任何地方都不需要这个类(class)。如果不打开单例类,流程将如下所示(假设原始代码中元类中定义的每个方法都将以self.为前缀):他们可以将Identity定义为classLetterAvatarclassIdentit
如果我有一个像下面这样的类,我如何判断祖先是类还是模块?ActiveRecord::Base.send(:include,SomeLibrary)classGroup["SubGroup","SomeLibrary::Core::InstanceMethods","SomeLibrary::Core","Group","ActiveRecord::Base","SomeLibrary","ActiveRecord::Aggregations","ActiveRecord::Transactions","ActiveRecord::Reflection","ActiveRecord::B
Ruby社区最近出现了大量关于使用更好的OO设计的好处的博客文章、推文和评论,特别是将业务逻辑与持久性逻辑分开。特别是对于较大的应用程序,我认为这是很好的建议。http://solnic.eu/2011/08/01/making-activerecord-models-thin.htmlhttp://blog.steveklabnik.com/2011/09/06/the-secret-to-rails-oo-design.htmlhttp://avdi.org/devblog/2011/11/15/early-access-beta-of-objects-on-rails-now-a
我有一个mixin,我想为它获取包含它的所有类的列表。在mixin模块中,我执行了以下操作:moduleMyModuledefself.included(base)@classes||=[]@classes这很好用:>MyModule.classes#=>nil>MyClass.new#=>#>MyModule.classes#=>["MyClass"]现在,我想将这部分提取到一个单独的模块中,该模块可以包含在我的其他mixins中。所以,我想出了以下办法:moduleListIncludedClassesdefself.included(base)p"...adding#{base.
我已经了解了如何将类定义为单例(howtocreateasingletoninRuby):require'singleton'classExampleincludeSingletonend但是如果我想在初始化单个实例时将一些参数传递给#new怎么办?示例应始终初始化某些属性。例如,假设我有一个类,其唯一目的是记录到一个文件,但它需要一个要记录到的文件的名称才能工作。classMyLoggerdefinitialize(file_name)@file_name=file_nameendend我怎样才能使MyLogger成为单例,但确保它获得一个文件名? 最佳答
我有一个脚本,该脚本使用不带参数的ObjectSpace#each_object进行迭代。然后它打印每个类存在多少个实例。我意识到有些类重新定义了#class实例方法,所以我不得不寻找另一种方法来获取实际的类;假设它存储在变量"klass"中,并且klass===object为真。在Ruby1.8中我可以这样做,假设Object没有被monkeypatched:Object.instance_method(:class).bind(object).call这适用于ActiveSupport::Duration实例:#Ruby1.8#(triestotrickus)20.seconds.
是否可以在ruby模块中声明静态方法?moduleSoftwaredefself.exitputs"exited"endendclassWindowsincludeSoftwaredefself.startputs"started"self.exitendendWindows.start上面的例子不会打印出“exited”。模块中只能有实例方法吗? 最佳答案 像这样定义您的模块(即使exit成为模块中的实例方法):moduleSoftwaredefexitputs"exited"endend然后使用extend而不是includ
这个问题在这里已经有了答案:HowtofindeachinstanceofaclassinRuby(4个答案)关闭7年前。在Ruby中有什么方法可以让一个类知道它存在多少个实例并可以列出它们?这是一个示例类:classProjectattr_accessor:name,:tasksdefinitialize(options)@name=options[:name]@tasks=options[:tasks]enddefself.all#returnlistingofprojectobjectsenddefself.count#returnacountofexistingprojects
如何在运行时向已定义的类添加实例变量,然后从类外部获取和设置它的值?我正在寻找一种元编程解决方案,它允许我在运行时修改类实例,而不是修改最初定义该类的源代码。一些解决方案解释了如何在类定义中声明实例变量,但这不是我要问的。 最佳答案 Ruby为此提供了方法,instance_variable_get和instance_variable_set。(docs)你可以像这样创建和分配一个新的实例变量:>>foo=Object.new=>#>>foo.instance_variable_set(:@bar,"baz")=>"baz">>fo
在Ruby中,我发现为了命名空间而将类放在模块中是很有用的。我还看到可以将模块放入类中。但我不明白你为什么要那样做。模块一般都是混入类的,对吧?那么,在类中定义模块的目的是什么? 最佳答案 我们可以在编写类似猿的代码时使用它:classDrugDealermoduleDrugdefhappy?;true;endenddefapproach(victim)victim.extendDrugendendo=Object.newDrugDealer.new.approach(o)o.happy?#=>true另一个在现实世界中更实用的示例