草庐IT

Java泛型传递参数

全部标签

ruby - 传递给 `instance_exec` 时如何执行 proc

问题的灵感来自thisone.Proc::new有一个选项可以在方法内部没有block的情况下调用:Proc::newmaybecalledwithoutablockonlywithinamethodwithanattachedblock,inwhichcasethatblockisconvertedtotheProcobject.当proc/lambda实例作为代码块传递时,将创建Proc的新实例:Proc.singleton_class.prepend(Module.newdodefnew(*args,&cb)puts"PROC#{[block_given?,cb,*args].i

ruby - 为什么 File.new 的参数不是符号而是字符串?

我想知道为什么编写File库的人决定用字符串而不是符号来确定文件打开模式的参数。比如现在是这样的:f=File.new('file','rw')但这不是更好的设计吗f=File.new('file',:rw)甚至f=File.new(:file,:rw)例如?这似乎是使用它们的最佳场所,因为参数绝对不需要可变。我很想知道为什么会这样。更新:我刚读完arelatedquestionaboutsymbolsvs.strings,我认为大家的共识是,符号只是不如字符串广为人知,反正大家都习惯用字符串来索引哈希表。但是,我认为Ruby标准库的设计者以对符号主题一无所知为由辩护是不合理的,所以我

ruby - 如何防止将位置参数扩展为关键字参数?

我想要一个接受散列和可选关键字参数的方法。我尝试定义这样的方法:deffoo_of_thing_plus_amount(thing,amount:10)thing[:foo]+amountend当我使用关键字参数调用此方法时,它按预期工作:my_thing={foo:1,bar:2}foo_of_thing_plus_amount(my_thing,amount:20)#=>21然而,当我省略关键字参数时,散列被吃掉了:foo_of_thing_plus_amount(my_thing)#=>ArgumentError:unknownkeywords:foo,bar如何防止这种情况发生

Ruby:自动将实例变量设置为方法参数?

是否有计划实现类似于在方法参数列表中指定实例变量名称的CoffeeScript功能的ruby​​行为?喜欢classUserdefinitialize(@name,age)#@nameissetimplicitly,but@ageisn't.#thelocalvariable"age"willbeset,justlikeitcurrentlyworks.endend我知道这个问题:inRubycanIautomaticallypopulateinstancevariablessomehowintheinitializemethod?,但所有的解决方案(包括我自己的)似乎都不符合ruby

ruby-on-rails - Rails 3 如何允许在没有_attributes 指定的情况下传递嵌套属性

当使用accepts_nested_attributes_for时,我不想传递“child_attributes”,而是传递“child”。我很确定,如果我在我的Controller中放入大量逻辑来创建记录和子项,我就可以完成此操作。但是,为了使我的Controller保持干净和逻辑应有的位置,即本例中的模型,我想知道如何在执行POST或PUT时切换rails3以使用此语法。{"name":"test","child_attributes":[{"id":1,"name":"test_child_update"},{"name":"test_child_create"}}相当{"nam

ruby - 在 JRuby 中,如何确定导致 java.lang.ThreadDeath 的原因?

在为一些与JRuby中的临时文件交互的代码运行单元测试时,我有时会得到以下信息:Exception:java.lang.ThreadDeaththrownfromtheUncaughtExceptionHandlerinthread"Thread-6395"它似乎没有引起任何问题,但这是怎么回事,我如何确定它发生在哪里?我尝试打开-d,但这并没有给我异常的堆栈跟踪。 最佳答案 FWIW:这可能与http://jira.codehaus.org/browse/JRUBY-7074有关.我偶尔会在不使用反引号但调用系统的JRuby程序中

ruby-on-rails - Ruby on Rails : get route using controller, 操作和参数

我对RoR很陌生,我正在寻找一种方法来为给定的Controller、操作和参数获取路由。类似于url_for()但没有域和协议(protocol)。假设我有:params={"controller"=>"controller","action"=>"edit","project_id"=>"1"}我需要得到:route="/controller/edit/1"如果我不需要手动构建路由并且不需要拆分url_for()的结果,那将是最好的。RoR本身是否支持这样的功能?这可能是一个简单的问题,但我找不到答案。 最佳答案 您应该能够使用以

ruby-on-rails - 具有强参数的 Rails 4 API?

我正在使用Rails4构建一个简单的API,但是使用我的“创建”方法时,一切都出错了。这是我的路线文件的相关部分:namespace:api,defaults:{format:'json'}do#/api/...Api::scopemodule::v1,constraints:ApiConstraints.new(version:1,default:true)doresources:usersendend这是api/v1/users_controller.rb:classApi::V1::UsersController[],:instrument_ids=>[])endend每当我尝试

ruby - 用 YARD 记录 "splatted"参数的最佳方法?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我有一个方法应该接受任何类的1+个参数,类似于Array#push:defmy_push(*objects)raiseArgumentError,'Needs1+arguments'ifobjects.empty?objects.eachdo|obj|puts"Anobjectwaspushed:#{obj.inspect}"@my_array.pushobjendend使用YARD语法记

ruby - 为什么带有无效参数的范围有时不会导致参数错误?

以下代码会导致参数错误:n=15(n%4==0)..(n%3==0)#=>badvalueforrange(ArgumentError)我认为这是因为它评估为:false..true并且范围内使用了不同类型的类:TrueClass和FalseClass。但是,以下代码不会引发错误。这是为什么?Enumerable#collect能捕捉到它吗?(11..20).collect{|i|(i%4==0)..(i%3==0)?i:nil}#=>noerror稍后添加:如果fcn返回15,则只评估范围的前半部分deffcn(x)putsx15endif(fcn(1)%4==0)..(fcn(2)