草庐IT

Block-scoped

全部标签

ruby - 标记未使用的 block 变量

当有block或局部变量不被使用时,有时人们用*标记它,有时用_标记。{[1,2]=>3,[4,5]=>6}.each{|(x,*),*|px}{[1,2]=>3,[4,5]=>6}.each{|(x,_),_|px}{[1,2,3],[4,5,6]}.each{|*,x,*|px}{[1,2,3],[4,5,6]}.each{|_,x,_|px}def(x,*),*;px;enddef(x,_),_;px;enddef*,x,*;px;enddef_,x,_;px;end它们之间有什么区别,什么时候应该使用哪个?当需要将多个变量标记为未使用时,如上例所示,哪个更好?

ruby - 将 proc 作为 block 提供给方法

假设我有以下数组:arr=[[5,1],[2,7]]而我要找最小的元素,比较元素的第二个元素。最小元素将为[5,1],因为1小于7。我可以使用以下代码:arr.min{|a,b|a[1]b[1]}为了计算最大值,我可以这样做:arr.max{|a,b|a[1]b[1]}这给出了[2,7]。我一直使用同一个block。我想将该block放在某处并将其提供给最小/最大函数。我希望是这样的:blo=lambda{|a,b|a[1]b[1]}arr.minblo会起作用,但它没有。关于如何执行此操作的任何想法? 最佳答案 使用&操作符将一个

Ruby - 退出 IF block

在IFblock中,我需要检查某些条件是否为真,如果为真,则退出block。#somethinglikethisif1==1returnifsome_object&&some_object.propertyputs'hello'end我该怎么做? 最佳答案 你不能像那样跳出if。您可以做的是向其添加一个子句:if(cond1)unless(cond2)#...endend如果您遇到逻辑嵌套过多的问题,并且需要一种更好地展平它的方法,也许您想做的是事先计算一个变量,然后仅在需要时才深入研究:will_do_stuff=cond1wil

ruby-on-rails - 使用 named_scope 获取行数

Rails专家:感谢另一位SO用户,我刚刚发现了named_scope。:)我想获取一组行的计数-即SELECTCOUNT(*)。此外,我希望仍然能够在调用中链接命名范围。这是命名范围的合法(尽管很奇怪)用法吗?named_scope:count,:select=>"COUNT(*)ascount_all"然后我可以做(例如):@foobar=Foobar.count.scope.scope.scope计数通过@foobar.first.count_all访问。(EditedtoaddressAllan'scomments)你可以这样做:@foobar=Foobar.scope.sco

ruby 在 block 中注入(inject)条件?

做第一个欧拉计划问题:将1到1000之间的3和5的倍数相加,我想到了这个(非常简单)sum=01.upto(999){|i|sum+=iif0==i%3||0==i%5}sum但我认为这行得通,但行不通,有人可以告诉我我做错了什么,或者为什么行不通吗?1.upto(999).inject(0){|sum,i|sum+iif0==i%3||0==i%5}谢谢! 最佳答案 inject将block的结果作为第一个参数传递到下一次迭代。当您的if语句为假时,您的block将返回nil,然后作为sum传回。为了得到正确的答案,当它为假时,该

ruby - 让 Ruby block /命令在没有空白 'rescue' block 的情况下静默失败

假设我想要运行一个调用,如果它失败了,也没什么大不了的;该程序可以继续没有问题。(我知道这通常是不好的做法,但想象一个假设的、快速的一次性脚本,而不是一个大项目)我被教导这样做的方式是:beginthing_to_tryrescue#awkwardblankrescueblockendnext_thing当然,还有其他方法可以做到这一点,包括使用ensure之类的。但是有没有办法让方法调用/block在没有困惑的空白block的情况下静默失败? 最佳答案 思路是一样的,只是少了一点冗长,不过你可以使用内联语法thing_to_try

ruby - 如何调用在不同上下文中获取 block 的 Proc?

以这个例子为例:proc=Proc.new{|x,y,&block|block.call(x,y,self.instance_method)}它有两个参数,x和y,还有一个block。我想为自己使用不同的值来执行该block。像这样的东西几乎可以工作:some_object.instance_exec("xarg","yarg",&proc)但是,这不允许您传入一个block。这也行不通some_object.instance_exec("xarg","yarg",another_proc,&proc)也没有some_object.instance_exec("xarg","yarg"

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 - ruby 中的 block 范围

我的理解是ruby​​block具有block作用域,并且在block内创建的所有变量将仅存在于block内。案例:food=['toast','cheese','wine']food.each{|food|putsfood.capitalize}putsfood输出:"Toast""Cheese""Wine""Wine"如果您在block(每个block)内使用food变量,我的理解是它具有block作用域。它只存在于block范围内,对外部变量food没有任何影响。但行为不同,在这种情况下修改了名为food的外部变量。这种理解是否正确,在ruby​​中我们有block作用域吗?

ruby - 'array.each do |block|'在生成的 Haml HTML 中包含语句的结果

我正在生成一封电子邮件,其中包含来自Haml模板的动态内容,该模板解析数组中的信息。基本上,Haml接收一个包含多个哈希值的数组。在代码中,我有一个如下所示的block:%table=arrayname.eachdo|object|%tr%td=object.name%td=object.link每当发送电子邮件时,整个对象arrayname都包含在HTML的底部。这会导致[#,#](当有更多对象时更多#)显示在block的顶部。没有办法用CSS操纵这段文本,否则我会把它隐藏起来。[#,#]该行与在IRB中执行代码时显示的结果相同。谁能告诉我如何防止这种情况发生?