"Is'eval'supposedtobenasty?"启发了这个:大多数人都认为eval不好,并且在大多数情况下有更优雅/更安全的替代品。所以我想问:如果eval经常被滥用,是否真的需要它作为一种语言特性?是不是弊大于利?就个人而言,我发现它唯一有用的地方是插入配置文件中提供的字符串。编辑:这个问题的目的是在eval是唯一或最佳解决方案时获得尽可能多的真实案例。所以请不要进入“语言是否应该限制程序员的创造力”的方向。Edit2:当我说eval时,我当然指的是eval字符串,而不是将rubyblock传递给instance_eval或class_eval.
我正在阅读ProgrammingRuby1.9的元编程部分,但我无法理解class_eval之间内部发生了什么|/class_exec与instance_eval/instance_exec.首先,我的理解是def在self的方法表中添加一个方法(类对象):classAputsself#=>Adeffoo;42;end#addedtothemethodtableofself,sobecomesaninstancemethodendA.new.foo#=>42如果我们使用class_eval,我们得到相同的行为:A.class_evaldoputsself#=>Adefbar;42;en
我知道这行得通:proc=Proc.newdoputsself.hi+'world'endclassUsadefhi"Hello!"endendUsa.new.instance_eval&proc但是我想将参数传递给proc,所以我尝试了这个不起作用:proc=Proc.newdo|greeting|putsself.hi+greetingendclassUsadefhi"Hello!"endendUsa.new.instance_eval&proc,'world'#doesnotworkUsa.new.instance_eval&proc('world')#doesnotwork谁能
我想使用instance_eval增强现有类。原始定义包含验证,这需要存在某些字段,即:classDummytrueend现在我想使用instance_eval(或任何其他方法,真的)将其更改为可选:Dummy.instance_evaldo...end删除验证的正确语法是什么,因此该字段是可选的。我宁愿直接在模型层上这样做,而不是在Controller或View中进行奇怪的修改。instance_eval的使用并不是真正必需的,但据我所知,这通常是增强Rails类的最佳方式。编辑#1一般来说-原始类是gem的一部分,我不想fork它,也不想绑定(bind)到特定版本。一般原因并不重要
Ruby有两种引用标准输入的方法:STDIN常量和$stdin全局变量。除了我可以将不同的IO对象分配给$stdin因为它不是常量(例如,在我的child中fork重定向IO之前)之外,还有什么STDIN和$stdin的区别?我什么时候应该在我的代码中使用它们?如果我重新分配$stdin,它会影响STDIN吗?这是否也适用于STDOUT/$stdout和STDER/$stderr? 最佳答案 如果$stdin重新分配,STDIN不受影响。同样$stdinSTDIN时不受影响被重新分配(这是完全可能的(尽管毫无意义),但会产生警告)。
它们是相同的,还是这两个命令之间存在细微差别? 最佳答案 gets将使用Kernel#gets,它首先尝试读取通过ARGV传入的文件的内容。如果ARGV中没有文件,它将使用标准输入代替(此时它与STDIN.gets相同。注意:正如echristopherson指出的那样,Kernel#gets实际上会退回到$stdin,而不是STDIN。但是,除非您将$stdin分配给不同的输入流,否则默认情况下它将与STDIN相同。http://www.ruby-doc.org/core-1.9.3/Kernel.html#method-i-ge
我正在尝试解决在Ruby1.8.6中eval()ing代码时出现的语法错误。我希望有以下Ruby代码:#!/usr/bin/rubygood_str="(1+1)"bad_str="(1+1"#syntaxerror:missingclosingparenbeginputseval(good_str)putseval(bad_str)rescue=>excputs"RESCUED!"end运行时产生如下结果:2RESCUED!相反,我得到的是:2eval_rescue.rb:8:(eval):1:compileerror(SyntaxError)(eval):1:syntaxerror
我正在学习如何在模块中使用class_eval(我对class_eval有点熟悉)并遇到了thishelpfulclassinresource_controller.那里有这样的东西:class_eval__FILE__和__LINE__在那个上下文中做了什么?我知道__FILE__引用当前文件,但整个事情到底做了什么?真的不知道如何搜索它:)。 最佳答案 __FILE__和__LINE__是一种动态常量,用于保存当前正在执行的文件和行。将它们传递到这里允许错误正确报告它们的位置。instance_eval当你运行它时$rubyfo
我正在阅读Module文档,但似乎无法理解它们之间的差异以及应该在何处使用。eval与exec有何不同? 最佳答案 我将通过在您的问题中包含instance_{eval|exec}来回答您的问题。{instance|module|class}_{eval|exec}的所有变体都会更改当前上下文,即self的值:classArraypself#prints"Array"43.instance_eval{pself}#prints"43"end现在说说区别。eval版本接受字符串或block,而exec版本只接受block但允许您向其传
Foo=Class.newFoo.class_evaldodefclass_bar"class_bar"endendFoo.instance_evaldodefinstance_bar"instance_bar"endendFoo.class_bar#=>undefinedmethod‘class_bar’forFoo:ClassFoo.new.class_bar#=>"class_bar"Foo.instance_bar#=>"instance_bar"Foo.new.instance_bar#=>undefinedmethod‘instance_bar’for#仅根据方法的名称,我