草庐IT

object-instances

全部标签

ruby - 如果 `main` 是 `Object` 的实例,为什么我不能调用它?

当我输入self时,我得到一个返回值main。我做了这个测试:main2=Object.new然后我可以调用main2,它会返回一些东西,但是当我调用main时,它会引发一个undefinedvariable错误。这是怎么发生的?以下是我在其他网站上发现的关于这个顶级环境如何工作的假设:classObjectObject.new.instance_evaldodefself.to_s"main"endprivate###Yourprogramgetsinsertedhere...##endend这对我来说很有意义。 最佳答案 “Wh

ruby-on-rails - 主要 :Object (NoMethodError) 的未定义方法 `require_relative'

在尝试更新OpenSSL时-我(似乎)破坏了笔记本电脑上Ruby和Rails的所有内容。即使在通过gemuninstall和rvmremove卸载ruby​​和rails之后,我仍然遇到此错误:Drews-MacBook-Pro:bookstoredrewwyatt$railsserverbin/rails:3:undefinedmethod`require_relative'formain:Object(NoMethodError)几个月来一切正常,直到我四处乱逛-更糟糕的是,我什至不确定我做了什么把事情搞砸了。额外信息Drews-MacBook-Pro:bookstoredreww

ruby-on-rails - RSpec::Mocks::ExampleMethods 的未定义方法 instance_double

我有一个这样的测试用例:describeWorkCardsControllerdoit"something"dowork_card=instance_double(WorkCard,{:started?=>true})#somemorecodeendend当我运行RSpec时,出现错误:undefinedmethod'instance_double'for#根据http://rubydoc.info/github/rspec/rspec-mocks/RSpec/Mocks/ExampleMethods这种方法存在。所以我尝试通过以下方式直接访问它:describeWorkCardsCo

ruby - 可能对 curry 过程进行 instance_eval 吗?

假设我有这样一个类:classTestdeftest_func140endend还有一个proc,它引用了Test中的一个成员函数:p=->(x,y){x+y+test_func}#=>#要调用p,我将它绑定(bind)到Test的一个实例:test=Test.new#=>#test.instance_exec(1,2,&p)#=>143现在假设我只想将y传递给p,并且始终传递x=1:curried=p.curry[1]#=>#理想情况下,我应该能够像以前一样instance_exec,但是:test.instance_exec(2,&curried)=>NameError:undef

ruby - 调用 ObjectSpace.count_objects 时哈希键的含义是什么?

在Ruby1.9(YARV)中,您可以获得所有当前已分配对象的计数,如下所示:ObjectSpace.count_objects它返回一个像这样的散列{:TOTAL=>1226560,:FREE=>244204,:T_OBJECT=>26141,:T_CLASS=>9819,:T_MODULE=>1420,:T_FLOAT=>287,:T_STRING=>260476,:T_REGEXP=>4081,:T_ARRAY=>72269,:T_HASH=>14923,:T_STRUCT=>4601,:T_BIGNUM=>7,:T_FILE=>16,:T_DATA=>54553,:T_MATC

ruby - 为什么 Ruby 定义 Object#=~?

阅读对anotherquestion中的答案的评论后并做了一些研究,我看到=~是在Object上定义的,然后被String和Regexp覆盖.String和Regexp的实现似乎采用了另一个类:"123"=~"123"#=>TypeError:typemismatch:Stringgiven/123/=~/123/#=>TypeError:can'tconvertRegexptoString虽然=~是为Object定义的,但是+不是:Object.new=~1#=>nilObject.new+1#=>undefinedmethod`+'for#为什么要定义Object#=~,而不是将=

ruby - 我可以将一个本身需要一个 block 的 block 传递给 ruby​​ 中的 instance_exec 吗?

我期待代码foo=proc{puts"foo"}instance_exec(1,2,3,&foo)do|*args,&block|puts*argsblock.callputs"bar"end输出123foobar但是报错bothblockargandactualblockgiven我可以将一个本身需要一个block的block传递给ruby​​中的instance_exec吗? 最佳答案 &foo尝试将foo作为block传递给instance_exec,而您已经传递了一个显式block。省略与号发送foo就像任何其他参数一样(除

ruby - 模块嵌套在 instance_eval/exec 或 module_eval/exec 中

我在尝试回答this时想到了这个问题.以下是预期的行为:moduleApModule.nestingend#=>[A]但是以下内容:A.instance_eval{pModule.nesting}A.instance_exec{pModule.nesting}A.module_eval{pModule.nesting}A.module_exec{pModule.nesting}全部返回[]。为什么这些不能像上面那样工作?附加问题Muistooshort提出了一个有趣的观点。如果这是正确的,那么Module.nesting将是依赖于文字上下文的方法和变量之一,例如Method#sourc

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

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

ruby - 主要 :Object 的未定义局部变量或方法 ` '

有时,以下会导致奇怪的错误:>nil|| 4NameError:undefinedlocalvariableormethod` 4'formain:Object>nil|| []NameError:undefinedlocalvariableormethod` 'formain:Object这是什么原因? 最佳答案 您不小心在Mac上键入Alt+Space,这会产生non-breakingspace.Ruby不将其视为空格,而是将其视为变量名的一部分。然后它提示变量不存在。SomepeopleliketoremapAlt+Space