jjzjj

self-documenting

全部标签

ruby - class << self 中的类定义是做什么的?

我知道如何添加类方法和类行为usingself(eigenclass).但是,在阅读somesourcecode时,我看到了另一种用法:classLetterAvatarclass这是如何运作的?它有什么作用,什么时候应该使用它?什么是(可能更被认可的)替代方式来写这个? 最佳答案 我认为他们这样做是因为他们在其他任何地方都不需要这个类(class)。如果不打开单例类,流程将如下所示(假设原始代码中元类中定义的每个方法都将以self.为前缀):他们可以将Identity定义为classLetterAvatarclassIdentit

Ruby:使用 self 关键字从内部调用私有(private)方法

classMyClassdeftestputsmy_idputsself.my_idendprivatedefmy_id115endendm=MyClass.newm.test此脚本产生输出:115priv.rb:4:in`test':privatemethod`my_id'calledfor#(NoMethodError)frompriv.rb:15:in`'使用self关键字和不使用关键字从内部调用方法有什么区别?根据我的Delphi和C#经验:没有区别,self可以用来避免与局部变量的名称冲突,表示我想调用实例函数或引用实例变量. 最佳答案

ruby self.class.class_eval 或 singleton_class.class_eval

我这样做有什么区别classTdefinitializeself.class.class_evaldodeftestreturnself.class.object_idendendendend和classTdefinitializesingleton_class.class_evaldodeftestreturnself.class.object_idendendendend谢谢附言。塔斯回答说在这个例子中,singleton_class会为每一个新的对象返回不同的object_id,因为一个singleton_class只属于一个Object。但是IRB显示下一个1.9.2p180:

ruby - yield self 和 yield 的区别?

谁能帮我理解“yieldself”和“yield”的区别?classYieldFirstLastattr_accessor:first,:lastdefinitialize(first=nil,last=nil)@first=first@last=lastyieldselfifblock_given?enddefhelloputs"#{@first}#{@last}sayshello!"endend 最佳答案 在yieldself的情况下,self是传递给block的参数。使用简单的yield,不传递任何参数。self在这里并不特殊

ruby - ruby 模块 self.included 和 self.extended 行为记录在哪里?

我正在查看rubymixin博客文章,它说当一个模块包含在一个类中时,它的self.included()方法被调用。我的问题是,这种行为的正式记录在哪里?我似乎无法在ruby​​-docs.org网站或镐上找到它。 最佳答案 虽然它不在RubyDoc上出于某种原因,included实际上已被记录。在终端中运行riModule.included提供以下内容:included(othermod)Callbackinvokedwheneverthereceiverisincludedinanothermoduleorclass.Thiss

ruby-on-rails - Rails,activerecord : self[:attribute] vs self. 属性

在Rails中访问事件记录列/属性时,使用self[:attribute]与self.attribute有什么区别?这会影响getter和setter吗? 最佳答案 它们都只是获取属性的方法-它们都只是getter。self.attribtue是一个更“传统”的getter,而self[:attribute]基本上只是[]方法。在使用两者之间切换不会产生任何影响。我建议只使用self.attribute方法,因为它在语法上更好。但是,当其他内容覆盖self.attribute方法时,使用self[:attribute]会派上用场。例

ruby-on-rails - *、self.* 和 @* 在 Ruby/Rails 模型/ Controller 中引用关联/属性时的区别

假设一个具有持久/非持久属性的Rails模型,关于引用它们的最佳实践是什么?如果您查看公开可用的代码,就会发现使用了不同的模式。例如,如果您有从一个模型到另一个模型的关联。使用self.association_name和@association_name有什么区别?。什么是更好的方式?与模型中使用attr_accessor:attr定义的非持久属性相同。您可以使用self.attr和@attr这两种方法来引用它们。什么是更好的方式? 最佳答案 self.x/self.x=y总是方法调用。(self.x只是self.__send__(

ruby - 在 Ruby 中是否有语法 : class << self . .. end 的任何相关应用程序

class上面的语法用于定义类实例变量。但是当我考虑语法意味着什么时,它对我没有任何意义,所以我想知道这种类型的语法是否用于任何其他类型的定义。我在这里的困惑点是:class附加运算符通常表示“将右侧的内容添加到左侧的对象”。但是在这个block的上下文中,这如何加起来“将这个block的内容放入类实例而不是实例的定义中”?出于同样的原因,我很困惑为什么在一个上下文中类classPoint#Instancemethodsgohereclass 最佳答案 在Ruby中,您可以重新打开现有类并添加方法。也就是说,你可以说:classFo

ruby-on-rails - 为什么使用 "self"访问 ActiveRecord/Rails 模型属性?

在我的整个应用程序中,self.没有必要引用用户名。name工作正常。为什么以下代码需要self才能按预期工作?classUser顺便说一句,我知道validates_presence_of可以用来防止保存,但如果没有给出名称,我想使用默认值保存。rails3.0.7。 最佳答案 通常使用self是为了强制Ruby将其识别为方法调用,而不是将其错误解释为变量。如果事先不知道名为day=的方法,那么day="x"在Ruby中看起来就像一个变量赋值。self.day="x"始终是方法调用。之所以麻烦是因为name和name=方法是在解析

ruby - 在 ruby​​ 中,self.method 和类 << self 中的方法有什么区别

classFoodefself.one;1endclass["two","one"]有人告诉我上述方法“一”和“二”在概念上是不同的,但我不明白是怎么回事。它们都是单例方法-在概念和应用上有什么区别? 最佳答案 在应用上,没有区别。在概念上,区别是微妙的,但在第一种情况下,您是在当前上下文中操作,并在另一个类实例上定义一个方法(实际上是其Eigenclass中的实例方法),而在第二种情况下,您正在进入其他类实例的元类(“Eigenclass”)的上下文,然后定义一个实例方法。编辑:我应该补充说选择class的原因在某些情况下是...