对数组和哈希进行排序是很常见的操作,ruby提供了丰富的方法和模块支持排序,但各个拍戏效能和使用倾向却有差异。
排序方法:sort,sort_by,sort_by {|x| block}
sort:
sort是最常规的升序方式排序,效率高,但是往往不是自己想要的排序方式。
sort_by:
sort_by当不带任何参数时,会返回一个Enumerator对象,该对象不是有序的。
sort_by {|x| block}
返回数组,可以指定排序的条件,效率不如sort,但可用性较高。
user system total real
sort 0.290000 0.000000 0.290000 ( 0.290314)
sort by 1.260000 0.000000 1.260000 ( 1.280853)
sort 0.290000 0.000000 0.290000 ( 0.290314)
sort by 1.260000 0.000000 1.260000 ( 1.280853)
这是对1000000随机hash排序的耗时,可以看出sort用时为sort_by的1/4左右。
因此,在我们选择方法时,需要根据实际情况选择最有效的方法。
参考资料: