在Ruby中取消定义方法非常简单,我可以使用undefMETHOD_NAME。类有类似的东西吗?我正在使用MRI1.9.2。我必须取消定义ActiveRecord模型,运行两行代码,然后将模型恢复为原始形式。问题是,我有一个模型Contact,我正在使用公司的API,碰巧他们有一些名为Contact的类,更改我的模型名称会对我来说是很多工作。遇到这种情况我该怎么办? 最佳答案 classFoo;end#=>nilObject.constants.include?(:Foo)#=>trueObject.send(:remove_con
我有一个名为Note的类,其中包含一个名为time_spent的实例变量。我希望能够做这样的事情:current_user.notes.inject{|total_time_spent,note|total_time_spent+note.time_spent}这可能通过混入Enumerablemodule来实现吗??我知道您应该将includeEnumerable添加到类中,然后定义一个each方法,但是each方法应该是类方法还是实例方法?each方法中的内容是什么?我正在使用Ruby1.9.2 最佳答案 这很简单,只需包含En
classAprivatedefinitializeputs"wtf?"endendA.new#stillworksandcallsinitialize和classAprivatedefself.newsuper.newendend完全没有效果那么正确的做法是什么?我想将new设为私有(private)并通过工厂方法调用它。 最佳答案 试试这个:classAprivate_class_method:newendMoreonAPIDock 关于ruby-如何在Ruby中使类构造函数私有(p
我刚开始学习rubyonrails,遇到过如下代码:classPost类体内有两个方法调用。我很难找到任何ruby文档描述了从类的主体内部(但在任何方法之外)进行的方法调用是如何工作的。我所有的书,只描述了如何定义类和实例方法以及如何从其他方法中调用它们。我的问题是:如何以及何时调用这些方法?它们是如何定义的?它们是在某个事件记录模块中定义的mixin吗? 最佳答案 类定义的主体是代码的执行上下文,就像其他代码一样。那里的代码在类的上下文中执行(意思是self是类对象,它是Class的一个实例)。您可以拥有局部变量和实例变量(它
我正在创建一堆迁移,其中一些是标准的“创建表”或“修改表”迁移,其中一些修改数据。我正在使用我实际的ActiveRecord模型来修改数据,ala:Blog.all.eachdo|blog|update_some_blog_attributes_to_match_new_schemaend问题是,如果我加载Blog类,然后修改表,然后再次使用Blog类,模型具有旧表定义,并且无法保存到新表。有没有办法重新加载类及其属性定义以便我可以重用它们? 最佳答案 答案是肯定的!Blog.reset_column_information
如何检查Ruby中是否已经存在一个类?我的代码是:puts"enterthenameoftheClasstoseeifitexists"nameofclass=gets.chompeval("#{nameofclass}......Notsurewhattowritehere")我正在考虑使用:eval"#{nameofclass}ancestors......" 最佳答案 您可以使用Module.const_get获取字符串引用的常量。它将返回常量(通常类由常量引用)。然后您可以检查常量是否是一个类。我会按照这些思路做一些事情:d
如何在Ruby中使用名称动态定义类?我知道如何动态创建一个类没有一个名字,使用类似的东西:dynamic_class=Class.newdodefmethod1endend但是你不能指定类名。我想用名称动态创建一个类。这是我想做的一个例子,但当然它实际上不起作用。(请注意,我不是在创建类的实例,而是在创建类定义)classTestEvaldefmethod1puts"name:#{self.name}"endendclass_name="TestEval"dummy=eval("#{class_name}")puts"dummy:#{dummy}"dynamic_name="TestE
我有一个模块MyModule。我动态地将类加载到其中。如何获取在其命名空间中定义的类的列表?例子:defload_pluginsDir.glob(File.dirname(__FILE__)+'/plugins/*.rb')do|f|MyModule.class_evalFile.read(f)end#nowhowcanIfindthenewclassesI'veloadedintoMyModule?end我应该说每个f都包含类似“classFoo;end”的内容。您也可以这样想:在Rails中,我如何以编程方式找到ActiveRecord模块中定义的所有类?
如何将字符串转换为类名,但前提是该类已经存在?如果Amber已经是一个类,我可以通过以下方式从字符串获取类:Object.const_get("Amber")或(在Rails中)"Amber".constantize但是,如果Amber还不是一个类,它们中的任何一个都会失败并返回NameError:uninitializedconstantAmber。我的第一个想法是使用defined?方法,但它不区分已经存在的类和不存在的类:>>defined?("Object".constantize)=>"method">>defined?("AClassNameThatCouldNotPoss
我正在通过用Ruby编写相当于KentBeck的xUnit的代码来扩展我对Ruby的理解。Python(Kent编写的语言)在广泛使用的语言中有一个assert()方法。ruby没有。我认为添加它应该很容易,但是Kernel是放置它的正确位置吗?顺便说一句,我知道Ruby中存在各种单元框架-这是学习Ruby习语的练习,而不是“完成某事”。 最佳答案 不,这不是最佳做法。Ruby中assert()的最佳类比就是提升raise"Thisiswrong"unlessexpr如果您想提供更具体的异常处理,您可以实现自己的异常