【发布时间】:2017-11-20 13:46:52
【问题描述】:
为什么哈希数组的内存大小在排序后会增加?
可以说,有一个哈希数组。如果我们检查该数组的内存大小,它的返回值为 44。 现在如果我对该数组应用排序,那么它的内存大小现在会增加。
require 'objspace'
array = [{:a=>1, :b=>1}, {:a=>1, :b=>3}, {:a=>1, :b=>2}, {:a=>1, :b=>4}, {:a=>1, :b=>6}, {:a=>1, :b=>7}]
ObjectSpace.memsize_of(array)
>> 44
ObjectSpace.memsize_of(array.sort_by{|x| -x[:b]})
>> 68
sorted_array = array.sort_by{|x| -x[:b]}
>> [{:a=>1, :b=>7}, {:a=>1, :b=>6}, {:a=>1, :b=>4}, {:a=>1, :b=>3}, {:a=>1, :b=>2}, {:a=>1, :b=>1}]
ObjectSpace.memsize_of(sorted_array)
>> 68
【问题讨论】: