本来打算按照复制的顺序输出,但是结果出乎预料。查了一下,hash本身就是无序的
之后又看到了日本人的一篇帖子
[url]http://gendosu.ddo.jp/redmine/wiki/1/Hash%E3%81%AE%E9%A0%86%E5%BA%8F%E3%82%92%E5%9B%BA%E5%AE%9A%E5%8C%96[/url]
ruby1.8 以下,Hash的顺序是不固定的
这里没有按照期望的c、b、a的顺序输出,不过可以借助rails的面封装的 ActiveSupport::OrderedHash 来实现
之后又看到了日本人的一篇帖子
[url]http://gendosu.ddo.jp/redmine/wiki/1/Hash%E3%81%AE%E9%A0%86%E5%BA%8F%E3%82%92%E5%9B%BA%E5%AE%9A%E5%8C%96[/url]
ruby1.8 以下,Hash的顺序是不固定的
h = Hash.new
h[:c] = 'c'
h[:b] = 'b'
h[:a] = 'a'
h.each_key do |k|
p k
end
#=> :c
#=> :a
#=> :b
这里没有按照期望的c、b、a的顺序输出,不过可以借助rails的面封装的 ActiveSupport::OrderedHash 来实现
h = ActiveSupport::OrderedHash.new
h[:c] = 'c'
h[:b] = 'b'
h[:a] = 'a'
h.each_key do |k|
p k
end
#=> :c
#=> :b
#=> :a