草庐IT

self-attention

全部标签

ruby - 了解 attr_accessor 类方法的 self

classTestclassTestputsTest.get_some.inspect=>Testnil在上面我可以找到self作为Test本身,但不返回some_data作为输出。但是当我按照以下方式进行修改时,它会返回预期的输出classTestclassTestputsTest.get_some.inspect=>Testsome_data有什么区别?编辑现在在第一个示例中,如果我将getsome方法设置为Test.some='new_data'putsTest.some.inspect#=>new_dataTest.set_someputsTest.get_some.inspe

ruby - 如果 `self` 始终是 Ruby 中的隐含接收者,为什么 `self.puts` 不起作用?

在Ruby中,我的理解是self是任何裸方法调用的隐含接收者。然而:~:irb>>puts"foo"foo=>nil>>self.puts"foo"NoMethodError:privatemethod`puts'calledformain:Object这是什么原因?如果有任何帮助:>>method(:puts).owner=>Kernel 最佳答案 私有(private)方法不能有接收者我认为答案是这样的:Ruby强制方法隐私的方式是它不允许使用显式接收者调用私有(private)方法。一个例子:classBakerdefbake

ruby - self.attribute 与 @attribute 的优势?

假设如下:defcreate_new_saltself.salt=self.object_id.to_s+rand.to_send为什么使用“self”更好。而不是实例变量“@salt”? 最佳答案 如果已定义,使用self.salt=将导致使用salt=方法。这对于确保使用salt=方法内的任何错误检查/转换很有用。然而,这意味着必须有一个明确的salt=方法(例如,可能由attr_accessor创建),这不一定是个好主意。总结:如果你有一个自定义的salt=方法,使用self.salt=;使用@salt=如果你确切地知道你想要

ruby-on-rails - `def self.myMethod` 和 `def myMethod` 之间有什么区别吗?

我正在同时学习ruby​​和ROR,并且在别人的代码中注意到一件事。有时我会看到以这两种明显略有不同的方式定义方法:classSomeClass这有什么区别吗?我的意思是,在方法定义中使用self会影响方法的工作方式吗?欢迎任何启发。 最佳答案 defself.method_name将定义一个类方法而不是实例方法-class关于该主题的一篇好文章是thispost来自耶胡达·卡茨例如:classFoodefmethod_1"calledfrominstance"enddefself.method_2"calledfromclass"

ruby-on-rails - self 在 ruby​​ on rails 中做什么?

我在railcasts上只是练习一些rails并且遇到了一些我试图理解的东西。我不明白authenticate方法中的“self”在做什么。所以我删除了它并测试了我的应用程序的登录以查看它是否会显示错误并且确实如此:error:**NoMethodErrorinSessionsController#createundefinedmethod`authenticate'for#如果有人能准确解释“self”在做什么,我将不胜感激。我试图弄清楚到底发生了什么,但无法理解它。方法在模型中定义并在sessions_controller中调用..我一直在不断删除我的应用程序,并从头开始以掌握它的

ruby - 修改 self ,Ruby

modulePiggedString.class_evaldodefpignewstring=self+self[0];newstring[0]="";newstring+="ay"returnnewstringendendend是相关代码。我想要做的是制作一个方法,pig!,它修改原始字符串。我该怎么做,而不修改self,因为这是不允许的......? 最佳答案 我稍微压缩了你的代码并添加了pig!方法:modulePiggedString.class_evaldodefpigself[1..-1]+self[0]+'ay'end

ruby - class << self 是什么意思?

关于:classTestclass我脑海中浮现出如下画面:因为在Ruby中一切都是对象,类本身就是类Class的对象。.调用class你打开ClassTest内部的定义并注入(inject)一些实例方法。自Test是Class的实例,您可以像在对象上调用实例方法一样调用这些方法:Test.hi.以下是有助于可视化我之前句子的伪代码:classClassdefhiputs“Hithere”endendTest=Class.new(classTestend)Test.hi我做对了吗? 最佳答案 假设我们有一个对象obj类A.此时,obj

ruby - 在 object.initialize 中,使用 self 是不是更好。超过 @?

有一种约定,在可能的情况下,通过对象的实例变量来引用对象的属性。PracticalObject-OrientedDesigninRuby说:Alwayswrapinstancevariablesinaccessormethodsinsteadofdirectlyreferringtovariables...这显示了一个例子,我已经释义了:classGearattr_reader:chainring,:cog...defratio#thisisbad#@chainring/@cog.to_f#thisisgoodchainring/cog.to_fend我看到使用实例变量创建新对象的最常

ruby - 如何像 instance_eval 方法那样在一个 block 中改变 self 呢?

instance_eval方法在其block中改变自身,例如:classD;endd=D.newd.instance_evaldoputsself#printsomethinglike#,not'main'!end如果我们自己定义一个方法(或任何其他方法(除了instance_eval)需要一个block),当打印self时,我们将得到'main',这与instance_eval方法不同。例如:[1].eachdo|e|putsself#print'main'end我如何定义一个像instance_eval这样的方法(需要一个block)?提前致谢。 最佳答

ruby-on-rails - 不理解类、模块和类 << self 方法

我有以下代码:classMyClassmoduleMyModuleclass当我调用方法时myfunction像这样,它工作正常:>me=MyClass::MyModule.myfunction=>"Nathan">me=>"Nathan"但是如果我删除了class并添加self.myfunction的前缀,它不起作用。例如:classMyClassmoduleMyModuleattr_accessor:first_namedefself.myfunctionMyModule.first_name="Nathan"endendend>me=MyClass::MyModule.myfun