一般Ruby问题:在Ruby中,我经常看到类内部的代码,而不是方法的一部分。例如:classDooDadattr_accessor:fooend或classTeacher我认为attr_accessor和has_many是分别使用:foo或:students参数调用的方法,是对的吗?如果是这样,这些语句何时执行。我试过这个:classDooDadattr_accessor:fooputs"Ihappened!"@foo=7endnew方法似乎没有运行这些部分:dd=DooDad.newdd.foo输出nil,并且从不吐出任何puts东西这一切究竟是如何运作的?
我有一个返回散列映射{:name=>"Test",:desc=>"TestDescription}的方法。它将始终返回:name和:description。如何用返回的哈希分配2个变量。我可以这样做,但它会调用该方法两次:@name,@desc=get_name_desc_map[:name],get_name_desc_map[:desc]我只想调用一次该方法。 最佳答案 使用Ruby的并行赋值非常简单:@name,@desc=get_name_desc_map.values另一种方法是(如果您不知道原始散列中键的顺序):@nam
以下问题与问题“RubyPrintInjectDoSyntax”有关。我的问题是,我们能否坚持使用do和end并使其与puts或p一起使用?这个有效:a=[1,2,3,4]b=a.injectdo|sum,x|sum+xendputsb#printsout10所以,这样说对吗,inject是Array对象的一个实例方法,这个实例方法接受一段代码,然后返回一个数字。如果是这样,那么它应该与调用函数或方法并取回返回值没有区别:b=foo(3)putsb或b=circle.getRadius()putsb以上两种情况,我们可以直接说putsfoo(3)putscircle.getRadi
我有一个使用Ruby标准库中的Set类的数据结构。我希望能够将我的数据结构序列化为JSON字符串。默认情况下,Set序列化为数组:>>s=Set.new[1,2,3]>>s.to_json=>"[1,2,3]"这很好,直到您尝试反序列化它。所以我定义了一个自定义的to_json方法:classSetdefto_json(*a){"json_class"=>self.class.name,"data"=>{"elements"=>self.to_a}}.to_json(*a)enddefself.json_create(o)newo["data"]["elements"]endend哪个
在true和false之间进行变量切换的最佳方法是什么?一个明显的方法是初始化一个变量foo:foo=false并做:foo=foo.!每次我想切换的时候。但是当变量名很长时,这会变得冗长。有没有更简单的方法来做到这一点(通过使用诸如语法糖、原始类之类的东西)?特别是,我想知道是否有一种方法可以通过只给它一个方法来切换:foo.some_method 最佳答案 您可以使用XOR运算符。foo^=truefoo=falsefoo^=true#=>truefoo^=true#=>false
我有一个方法foo,它在脚本script001.rb中被调用我应该如何编写foo方法,以便它返回调用它的脚本的文件名? 最佳答案 为了避免需要处理caller风格的字符串,你可以使用Kernel#caller_locations,反而。它返回一个数组Thread::Backtrace::Location对象,它有一些方便的方法供您使用。要获取文件名,在您的情况下,您可以使用#path方法:deffoocaller_locations.first.pathend 关于ruby-在调用方法的
我使用的是ruby1.8.7。我可以发誓我之前已经在脚本底部编写了我的函数并且运行良好。我必须将它们放在顶部吗?这似乎是他们现在唯一的工作方式。没什么大不了的。我只是更喜欢将它们放在底部,所以我想我会问。 最佳答案 您可以在一个或多个BEGINblock中执行初始化代码(继承自Perl,后者继承自awk)。can_i_do_this?#=>yesBEGIN{defcan_i_do_this?puts"yes"end}为了完整起见,还有ENDblock:END{can_i_do_this?#=>yes}defcan_i_do_th
如果类定义中包含初始化方法,是否需要显式初始化对象? 最佳答案 不,Ruby不会自动调用initialize。Class#new的默认实现看起来有点像这样:classClassdefnew(*args,&block)obj=allocateobj.initialize(*args,&block)objendend[实际上,initialize默认是private,所以你需要使用obj.send(:initialize,*args,&block)。]因此,Class#new的默认实现确实调用了initialize,但完全有可能(尽管非
比如单词“stack”,我想得到一个像这样的数组:['s','st','sta',...'stack','t','ta',...,'c','ck','k']我是通过这样的代码做到的:defsplit_word(str)result=[]chas=str.split("")len=chas.size(0..len-1).eachdo|i|(i..len-1).eachdo|j|result.push(chas[i..j].join)endendresult.uniqend有没有更好、更干净的方法来做到这一点?谢谢。 最佳答案 defs
我找到了很多关于添加表单辅助方法的信息(参见我的其他问题之一),但是我找不到任何关于添加辅助方法的信息,就好像它们是在application_helper.rb中定义的一样>.我试过将Rails应用程序中的application_helper.rb复制到gem中,但这没有用。我也试过:classActionView::Helpers..但这会产生错误。 最佳答案 在某处为您的辅助方法创建一个模块:moduleMyHelperdefmymethodendend将其混合到ActionView::Base中(例如在init.rb或lib/