草庐IT

ruby - 为什么 Array#each 返回具有相同元素的数组?

我正在学习each如何在ruby​​中工作的细节,我尝试了以下代码行:p[1,2,3,4,5].each{|element|el}结果是一个数组[1,2,3,4,5]但我不认为我完全理解为什么。为什么each的返回值是同一个数组?每个人不只是提供一种迭代方法吗?或者只是each方法返回原始值的常见做法? 最佳答案 Array#each返回调用它的[array]对象:block的结果是discarded。因此,如果原始数组没有icky副作用,那么什么都不会改变。也许你的意思是使用map?p[1,2,3,4,5].map{|i|i*i}

arrays - Ruby 2.0.0 Array#bsearch 行为

我注意到从Ruby2.0.0开始,数组类有一个我正在测试的bsearch方法,但我没有得到我期望的行为。为什么它返回2和5的值,但返回-1、1和4的nil?arr_in=[-1,1,2,4,5]arr_in.bsearch{|x|x==3}#=>nilarr_in.bsearch{|x|x==-1}#=>nilarr_in.bsearch{|x|x==1}#=>nilarr_in.bsearch{|x|x==2}#=>2arr_in.bsearch{|x|x==4}#=>nilarr_in.bsearch{|x|x==5}#=>5 最佳答案

ruby-on-rails - 空元素是否有等效的 Array#compact ?

众所周知,Array#compact从数组中删除了nil元素。array.reject{|元素|元素.空?}会删除像[]这样的空元素(在rails中你也可以使用#blank?来删除空元素和无元素)。有没有像Array#compact这样的删除空/空白元素的简写方法?还是使用Array#reject是我最好的选择?我还没有看到#compact的“空”等价物,如果有的话。但也许我只是忽略了它。 最佳答案 是的!array.reject&:empty?然而,作为scarver2和HoangLe解释说,这将失败并显示NoMethodErro

arrays - 获取数组的每n个元素

如何使用Ruby1.9+选择数组的每个n个元素(例如六个)?示例:a=[0,1,2,3,4,...,33]#solution#=>[[0,1,2,3,4,5],[6,7,8,9,10,11],...] 最佳答案 Enumerable#each_sliceIteratesthegivenblockforeachsliceofelements.Ifnoblockisgiven,returnsanenumerator.e.g.:(1..10).each_slice(3){|a|pa}#outputsbelow[1,2,3][4,5,6][

ruby-on-rails - 文字和构造函数之间的区别? ([] 与 Array.new 和 {} 与 Hash.new)

我很想知道[]和Array.new以及{}和Hash.new之间的更多区别我对它进行了相同的基准测试,似乎简写是赢家require'benchmark'many=500000Benchmark.bmdo|b|b.report("[]\t"){many.times{[].object_id}}b.report("Array.new\t"){many.times{Array.new.object_id}}b.report("{}\t"){many.times{{}.object_id}}b.report("Hash.new\t"){many.times{Hash.new.object_id

Ruby - Array.join 与字符串连接(效率)

我记得有一次因为在Python中连接字符串而受到责骂。有人告诉我,在Python中创建一个字符串列表并稍后加入它们会更有效。我将这种做法应用到JavaScript和Ruby中,尽管我不确定这在后者中是否有同样的好处。谁能告诉我在Ruby编程语言中加入字符串数组并调用:join或根据需要连接字符串是否更有效(在资源和执行方面)?谢谢。 最佳答案 自己用Benchmark试试类。require"benchmark"n=1000000Benchmark.bmbmdo|x|x.report("concatenation")dofoo=""n

ruby - 使用 step 遍历数组

我想查看数组中的每个第n个元素。在C++中,我会这样做:for(intx=0;x我想在Ruby中做同样的事情,但找不到“步骤”的方法。while循环可以完成这项工作,但我发现在已知大小的情况下使用它令人反感,并希望有更好的(更多Ruby)方法来完成这项工作。 最佳答案 范围有一个step方法,您可以使用它来跳过索引:(0..array.length-1).step(2).eachdo|index|value_you_care_about=array[index]end或者,如果您习惯于将...与范围一起使用,则以下内容更简洁一些:(

ruby 1.9 : Convert byte array to string with multibyte UTF-8 characters

我正试图在Ruby中找到一种方法来获取UTF-8字节数组并将其转换回字符串。在irb(Ruby1.9.2预览版3)中,我可以从UTF-8字符串创建正确的字节数组:ruby-1.9.2-preview3>'Café'.bytes.to_a=>[67,97,102,195,169]但是,我找不到从字节返回数组的方法。我尝试将Array.pack与U*选项一起使用,但这不适用于多字节字符。ruby-1.9.2-preview3>[67,97,102,195,169].pack('U*')=>"Café"有没有人知道如何将包含多字节字符的UTF-8字节数组转换回字符串?谢谢。

ruby - 在 Ruby 中对字符串数组进行排序

我在Ruby中学习了两种数组排序方法:array=["one","two","three"]array.sort.reverse!或:array=["one","two","three"]array.sort{|x,y|yx}我无法区分这两者。哪种方法更好,它们在执行上究竟有何不同? 最佳答案 这两行做同样的事情(创建一个新的数组,它是反向排序的)。主要争论是关于可读性和性能。array.sort.reverse!比array.sort{|x,y|yx}更具可读性-我想我们可以在这里达成共识。对于性能部分,我创建了一个快速基准测试脚

Ruby Array concat 与 + 速度?

我对Ruby的数组concat()与+操作进行了小型性能测试,concat()速度太快了。但是我不清楚为什么concat()这么快?有人可以帮忙吗?这是我使用的代码:t=Time.nowar=[]foriin1..10000ar=ar+[4,5]endputs"Timefor+"+(Time.now-t).to_st=Time.nowar=[]foriin1..10000ar.concat([4,5])endputs"Timeforconcat"+(Time.now-t).to_s 最佳答案 根据Rubydocs,不同之处在于:数组