时间:2021-07-19 08:01:38 | 栏目:Ruby | 点击:次
最近在学习Rails,因为学习的java为入门语言.些许的不太适应.特别是Ruby的Hash.不过细细的想想就通了.基本上都是通的Key-Value.除了刚开始不太适应写法没什么大的问题.这个是我在网上看到的一篇日志.
1. 如何创建Hash?
这些都是创建Hash的方法。
第一个和第二个一样,表示创建空的Hash.
第三个表示创建的Hash,有2对键/值。
2. Hash的键是哪些类型?
可以是任何目标,如:
有两点注意:
(1)任何目标包括数组、Hash都可以是Key。
(2)使用字符作为Key时,最好使用对应的符号。例如,键"a"可以用:a来代替。这是因为每个字符"a"都是一个目标,而:a是唯一的,
更节省内存。
3. 如何给Hash赋默认的值?
表示创建一个Hash,它的默认值是空的数组[]。
然后访问x[:a],虽然这个键没有事先定义,但还是有默认值。
请注意:这种方法赋的默认值,都指向同一个目标,这个目标改变了,会影响到所有默认值。
要做到每个键都对应唯一的默认值,应该如此创建Hash:
让我们再看看:
一个值的改变,不会影响到其他默认值。
4. 如何遍历Hash?
irb(main):019:0> x.each do |k,v| puts "#{k} #{v}" end
5 6
1 2
3 4
=> {5=>6, 1=>2, 3=>4}
使用Hash的each方法。
5. 如何遍历Hash的Key和Value?
irb(main):021:0> x.values.each do |v| puts v end
使用Hash的keys和values方法,它们返回一个数组。
当然还可以使用each_key和each_value方法,顾名思义就是遍历key和value.
6. Hash可以sort吗?
ruby的hash实际是可以sort的,返回一个sort后的二维数组。
irb(main):028:0> x.sort
=> [[1, 2], [3, 4], [5, 6]]
另外ruby有OrderedHash这个类,它可以让Hash元素按插入顺序来sort,类似于数组的能力。
7. 如何从Hash里添加和删除元素?
增加元素,直接定义Key/Value:
irb(main):041:0> x
=> {5=>6, 1=>2, 7=>8, 3=>4}
irb(main):043:0> x
=> {5=>6, 1=>2, 3=>4}
当然也可以用delete_if带条件的删除Hash元素。例如删除所有Key大于3的:
8. 如何查找Hash元素?
使用has_key?和has_value?来判断是否有对应键和值:
irb(main):053:0> x.has_value? 4
=> true
irb(main):054:0> x.has_key? 9
=> false
考虑到默认值的情况,不能直接用if hash[:key]来判断,例如:
irb(main):056:0> y.has_key? :a
=> false
irb(main):057:0> puts 1 if y[:a]
1
=> nil
其他的查找方法,还有find、select等,例如找到所有Key大于2的元素:
9. 可以反转Hash吗?
答案是可以,使用invert方法:
irb(main):012:0> x.invert
=> {6=>5, 2=>1, 4=>3}
10. Hash和数组如何转换?
Hash转换到数组很简单:
数组转换到Hash麻烦一点,自己写一个方法to_hash:
irb(main):033:0> x=[1,2,3,4,5,6]
=> [1, 2, 3, 4, 5, 6]
irb(main):034:0> x.to_hash
=> {5=>6, 1=>2, 3=>4}
11. Hash的丢值行为?
任何时候修改了Hash的Key(记住Key是包括数组在内的目标),都会发生丢值行为。
上述修改了键x的值,那么这个键对应的Value就丢失了。
解决办法是rehash。任何时候修改了Key的值,都要rehash一次。