草庐IT

hook_event_proc

全部标签

ruby - 为什么 proc 可能比 block 运行得更快?

Thisanswer在另一个问题上说array.map(&:to_s)比快array.map{|n|n.to_s}在第一个例子中,&把:to_s变成一个Proc。第二个例子使用了一个block。为什么Proc在该基准测试中可能比block快?这种技术是否允许解释器进行一些优化? 最佳答案 这并不是关于“procvsblock”。下面是一个简单的实验(随意复制运行):require'benchmark'many=500array=(1..10000).to_aproc=proc{|a|a.to_s}Benchmark.bmdo|x|x

ruby - 这是 Method#to_proc 中的错误吗? ( ruby 1.8.7)

给定以下采用一个参数的方法:deffoo(arg);parg;end我可以用一个空数组来调用它:foo([])#prints[]我也可以将它保存为一个Method对象并用一个空数组调用that,结果相同:method(:foo).call([])#prints[]但是,如果我将Method对象转换为Proc并使用空数组调用that,我会得到一个ArgumentError:method(:foo).to_proc.call([])#ArgumentError:wrongnumberofarguments(0for1)#from(irb):4:in`foo'#from(irb):4:in`

ruby-on-rails - 为什么使用 Proc.new 来调用 Rails 回调中的方法?

在RoR的所有教程中,我看到了编码人员选择使用Proc.new的实例,而这似乎既不必要又相当没有吸引力。例如,这是一个放置在模型中的回调,一个使用Proc.new,另一个可能做同样的事情:classOrderProc.new{|order|order.paid_with_card?}endclassOrder"paid_with_card?"end那有什么区别呢?为什么要使用过程?他们不都叫“paid_with_card”吗?方法?提前致谢 最佳答案 在上面的示例中,为条件方法使用符号可能是最佳选择。classOrder:paid_

ruby - 内省(introspection)模块类时 "#map(&proc)"习惯用法如何工作?

呈现成语我找到了一个interestingbutunexplainedalternative到一个公认的答案。该代码在REPL中显然有效。例如:moduleFooclassBardefbazendendendFoo.constants.map(&Foo.method(:const_get)).grep(Class)=>[Foo::Bar]但是,我并不完全理解这里使用的成语。特别是,我不明白&Foo的用法,它似乎是某种闭包,或者#grep的这种特定调用如何对结果进行操作。解析成语到目前为止,我已经能够解析其中的点点滴滴,但我并没有真正看到它们是如何组合在一起的。以下是我认为对示例代码的理

ruby-on-rails - rails 4 - stripe_event 函数

我正在使用带有stripe和stripe_eventgem的Stripe支付服务。到目前为止一切顺利——它们工作得很好。我想使用stripe_eventwebhooks监听器来执行一系列操作。例如,当Stripe发送webhook建议申请新订阅时,我想将该订阅添加到subscriptions表,向新用户发送电子邮件,建议管理员等。在(非常少的)stripe_eventdocs在github上,他们说使用call方法订阅一个对象,并将示例显示为classCustomerCreateddefcall(event)#Eventhandlingendend但是它们没有显示此代码的位置(它将放置

ruby-on-rails - 需要对 proc 和 lambda 进行令人难忘的解释

我已经尝试阅读有关过程和lambda的内容,但我必须继续重新阅读定义。谁能用清晰易记的方式向我解释一下? 最佳答案 已编辑:在这里阅读了其他好的答案后,我提供以下提炼,可能会节省您一些重读时间:(l)ambda-(L)ocalreturn(L)ooksatthearguments(p)roc-(P)opsyououtofthemethodwhenitreturns.(P)ermitsdifferentarguments爱因斯坦说“......让事情尽可能简单,但不要更简单。”如果他有堆栈溢出,他会把你指向这里:Whatarethed

Ruby block 、procs 和 instance_eval

我最近尝试做类似的事情:a="somestring"b=Proc.new{upcase}a.instance_evalb这给出了错误:TypeError:can'tconvertProcintoString但这行得通:defb(&block)"somestring".instance_eval&blockendb{upcase}进一步了解此方法:defb(&block)"somestring".instance_evalblockend产生相同的ProctoString错误。所以...我对方block的理解是它们只是过程。但是显然,使用这个&符号有一些特别之处......有人能给我解释

Ruby:将 proc 转换为 lambda?

是否可以将proc风格的Proc转换为lambda风格的Proc?有点惊讶这行不通,至少在1.9.2中是这样:my_proc=proc{|x|x}my_lambda=lambda&pmy_lambda.lambda?#=>false! 最佳答案 追踪这个有点棘手。查看Proc#lambda?for1.9的文档,关于proc和lamdba之间的区别有相当长的讨论。归根结底,lambda会强制执行正确数量的参数,而proc则不会。从该文档中,此示例显示了将proc转换为lambda的唯一方法:define_methodalwaysdef

ruby - 如何评估 `Proc#==`?

Proc#==是如何计算的?RDoc说:prc==other_proc→trueorfalseReturnstrueifprcisthesameobjectasother_proc,oriftheyarebothprocswiththesamebody.但不清楚什么才算“同体”。一个条件似乎是arity必须相同:->{}==->{}#=>true->{}==->x{}#=>false->x{}==->x{}#=>true->x{}==->y{}#=>true->x{}==->y,z{}#=>false但不止于此。正如RDoc所说,body很重要:->{nil}==->{nil}#=>t

ruby - 任务钩子(Hook)前 rake

有没有直接的方法来修改Rake任务以在运行现有任务之前运行一些代码?我正在寻找相当于增强的东西,它在任务开始而不是结束时运行。Rake::Task['lame'].enhance(['i_run_afterwards_ha_ha']) 最佳答案 您可以使用Rake任务的依赖项来执行此操作,事实上Rake允许您重新定义现有任务。Rakefiletask:your_taskdoputs'your_task'endtask:beforedoputs"before"endtask:your_task=>:before结果$rakeyour_