让我们来看一个普通的ruby类:classPersonattr_accessor:namedefinitializename@name=nameendendbob=Person.new("bob")我的问题是初始化的性质。事情是这样的,new显然是一个类方法,但在我看来initialize是一个实例方法(不是类),它在类方法创建的实例上调用new被调用。我有这个权利吗?或者有人可以阐明一些新的观点吗?我做了一些谷歌搜索,但找不到任何清晰度。 最佳答案 当一个新对象被初始化时(也就是说,当你在一个类上调用new时)有效调用的是这个
这个错误已经有好几个月了,在这里:http://www.ruby-forum.com/topic/1094002其中显示代码更改的两个链接:https://github.com/godfat/ruby/commit/f4e0e8f781b05c767ad2472a43a4ed0727a75708https://github.com/godfat/ruby/commit/c7a6cf975d88828c2ed27d253f41c480f9b66ad6我有Ruby1.9.2和rvm。我会把这些更改粘贴到适当的文件中,但我不知道如何粘贴。这在几天前就奏效了。我不能像这样执行RubyonRai
今天我在Rational中遇到了奇怪的ruby语法类:Rational(a,b)(请注意,与普通的Ruby语法相比,缺少.new()部分)。与普通的new语法相比,这究竟意味着什么?更重要的是,我如何在自己的代码中实现这样的东西,为什么要实现这样的东西?专门针对Rational类,为什么使用这种语法而不是正常的实例化呢?为什么new方法在rational类中是私有(private)的?(以及我如何/为什么要在我自己的ruby代码中这样做?)预先感谢您的回答,特别是因为我问了这么多问题。 最佳答案 您所要做的就是声明一个与您的
它是如何工作的?运行以下代码时,"hifromclass"会打印两次。ruby内部发生了什么使它表现得像这样?我实际上不是在为类创建实例方法吗classClassdeffooputs"hifromclass"endendClass.foox=Class.newx.foo 最佳答案 我不知道你是否意识到这一点,但是当你执行classClass...end时,你并没有创建一个名为Class,您正在重新打开现有类Class。由于Class是所有类都是其实例的类,这意味着Class是其自身的实例。因此,您可以直接在Class上调用Class
class之间有什么区别?和Class.new&module和Module.new?我知道:Class.new/Module.new创建一个匿名class/module.当我们第一次将它分配给常量时,它变成了那个class的名称。/module.class/module自动执行此操作。当我们想要继承时,我们可以传递一个参数:Class.new(ancestor).当我们不指定祖先时,它被设置为Object.class使用此语法:classAClass.new返回object.classA返回nil.同样适用于module秒。我错过了什么吗? 最佳答案
如果要让用户能够共享一个私有(private)链接,让任何点击它的人都能查看具有隐私限制的特定页面/文档/项目,最好的方法是什么?以我为例:用户创建的事件仅限于数据库中某些关系组(即:friend、friend的friend等)我在事件Controller中有一个:before_filter检查资格当前登录用户的权限,以确保该用户有权查看该事件。如果他们不这样做,他们将被引导到根页面并显示一条错误消息。但是,我希望存在一个特殊场景,用户可以使用相同的隐私设置创建一个事件,此外,还可以通过电子邮件、Facebook等方式与他或她的friend分享一个特殊链接。那些用户不需要帐户(但需要创
假设有下面这个类#derp.rbclassDerp当我加载“./derp.rb”两次时,程序因TypeError:superclassmismatchforclassDerp而失败。好的,这可以通过require来管理。但是我如何为每次使用Spork的测试运行重新加载这些类?require显然不会工作,因为它会缓存加载的文件。 最佳答案 Struct.new正在为您的每次加载创建新类。irb(main):001:0>classTest1classTest1'您可以将返回的Struct.newclass保存到一个变量中,然后您可以使用
在尝试rake:dbmigrate之后,我在终端中得到了这个错误rakeaborted!ArgumentError:Unknownkey::conditions.Validkeysare::class_name,:class,:foreign_key,:validate,:autosave,:table_name,:before_add,:after_add,:before_remove,:after_remove,:extend,:primary_key,:dependent,:as,:through,:source,:source_type,:inverse_of,:counter
我见过使用类引发异常的Ruby代码:raiseGoatException,"Maximumof3goatsperbumpercar."其他代码使用实例:raiseGoatException.new"Noleotardfoundsuitableforgoat."这两个都是以同样的方式获救的。是否有理由使用实例而不是类? 最佳答案 没有区别;在任何一种情况下都会实例化异常类。如果您提供一个字符串,作为new的参数或作为raise的第二个参数,它会被传递给initialize并且将成为异常实例的.message。例如:classGoatE
我对Ruby的理解是“new”关键字总是与类名结合使用以创建类的新实例。在下面的代码中,可在https://gist.github.com/e9c0da1a6e92dd12cbc7找到,这是作为Ruby新手编程挑战赛的解决方案提交的,作者在没有实例化类的情况下使用了“new”关键字三次。在一种情况下,new(0,0)被分配给常量CLOSED。在另一种情况下,new(open,close)是函数的返回值。为什么要这样做?以这种方式使用时,"new"在做什么?它在创造什么?classOpenHoursattr_reader:open,:closedefinitialize(open,clo