草庐IT

Self-requirement

全部标签

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

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

ruby - 了解 `load` 、 `require` 和 `require_relative` 之间的区别

我不明白导入库或模块的三种方法之间的区别。据我目前的了解,load'file.rb'会将外部文件的内容导入当前文件而:require'file.rb'将执行相同的功能,但不会导入已经导入的文件。require_relative'file.rb'类似于require,但它将加载仅在当前目录中的文件,而require将使用搜索路径$:试图找到该文件。我毫不怀疑我对这三种机制的理解是有缺陷的。谁能提供一些说明? 最佳答案 load在您想要导入文件时使用,无论它是否已经导入。require或require_relative仅当您想要导入尚未

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

ruby-on-rails - require 和 load 有什么区别?

使用有什么区别:require'digest'和load'digest' 最佳答案 如果您需要同一个文件两次,它只会被加载和计算一次。另一方面,load每次都会加载和计算文件。实际文件名的解析方式也存在差异(thanks,Saurabh)。这实际上意味着什么?假设我们有一个库foo#foo.rbclassFoodefbarputs'bar'enddefquuxputs'quux'endend然后我们有一个文件进行一些非幂等操作。比如说,取消定义一个方法#mod.rbclassFooundef:barend然后,如果我们require

ruby - "const_missing"定义中缺少常量和 "class << self"

在定义const_missing时,我对Ruby的行为感到非常困惑和class中的其他类方法定义而不是使用defself.foo句法。我正在尝试做这样的事情:classFooclass我主要使用class定义类方法的语法。但是,它没有按预期工作。const_missing永远不会被调用。以上结果导致NameError。像这样定义这两种方法按预期工作:defself.fooputsMISSINGenddefself.const_missing(name)puts"#{name}missing"end我认为classsyntax只是定义类方法的另一种方式,但完全等同于defself.foo

Ruby 在没有显式包含声明的情况下在子类上执行 self.included(base) 方法?

我有许多继承自一个父类(superclass)的类。作为模块定义的父类(superclass)。模块内部是一个设置一些实例变量的self.included(base)方法。所以像这样:moduleMyModuledefself.included(base)base.instance_variable_set("@my_instance_variable",{})endendclassMySuperClassincludeMyModuleendclassClassA除非我明确地将MyModule包含在ClassA和ClassB中,否则我的实例变量将不会在这两个类中设置。有没有办法确保在每

ruby - `require' : cannot load such file -- spec_helper (LoadError)

我在创作bundlergem--test=rspecMyGem.我在其中获取存储库结构。当我尝试运行rspec代码时,出现以下错误:`require':cannotloadsuchfile--spec_helper(LoadError)然后我尝试应用requirerelative但我仍然收到错误:sheetal@ubuntu:~/sheetal/spec$rspecsheetal_spec.rb\/home/sheetal/.rvm/rubies/ruby-2.2.0/lib/ruby/2.2.0/rubygems/core_ext/kernel_require.rb:54:in`re

ruby - 为什么 'undefined method ` assert_equal' ' is thrown even after requiring ' test/unit'

我打开irb并输入:require'test/unit'但是当我使用assert_equal方法时,出现以下错误:NoMethodError:undefinedmethod'assert_equal'formain:Object。为什么即使在需要“测试/单元”之后也会发生这种情况? 最佳答案 assert_equal是在Test::Unit::TestCase的子类上定义的,因此仅在该类中可用。您可能会成功地使用includeTest::Unit::TestCase将这些方法加载到当前范围。更有可能的是,您最好将测试写在一个短文件中

ruby - 为什么 self.class === MyClass 返回 false,而 self.class == MyClass 返回 true?

我正在使用Ruby的case语法来设置一些基于self.class的简单逻辑,如下所示:caseself.classwhenFirstClassdostuff....whenSecondClassdootherstuff...end我很快意识到这总是返回nil。经过仔细调查,我发现case使用===而不是==检查是否相等。在我的终端中运行self.class==FirstClass时,我按预期得到true,但是self.class===FirstClass返回假的。查看ruby​​文档,我找到了followingexplanation===:CaseEquality–ForclassO