最近在學(xué)習(xí)Rails,因?yàn)閷W(xué)習(xí)的java為入門語言.些許的不太適應(yīng).特別是Ruby的Hash.不過細(xì)細(xì)的想想就通了.基本上都是通的Key-Value.除了剛開始不太適應(yīng)寫法沒什么大的問題.這個是我在網(wǎng)上看到的一篇日志.
1. 如何創(chuàng)建Hash?
這些都是創(chuàng)建Hash的方法。
第一個和第二個一樣,表示創(chuàng)建空的Hash.
第三個表示創(chuàng)建的Hash,有2對鍵/值。
2. Hash的鍵是哪些類型?
可以是任何目標(biāo),如:
有兩點(diǎn)注意:
(1)任何目標(biāo)包括數(shù)組、Hash都可以是Key。
(2)使用字符作為Key時(shí),最好使用對應(yīng)的符號。例如,鍵"a"可以用:a來代替。這是因?yàn)槊總€字符"a"都是一個目標(biāo),而:a是唯一的,
更節(jié)省內(nèi)存。
3. 如何給Hash賦默認(rèn)的值?
表示創(chuàng)建一個Hash,它的默認(rèn)值是空的數(shù)組[]。
然后訪問x[:a],雖然這個鍵沒有事先定義,但還是有默認(rèn)值。
請注意:這種方法賦的默認(rèn)值,都指向同一個目標(biāo),這個目標(biāo)改變了,會影響到所有默認(rèn)值。
要做到每個鍵都對應(yīng)唯一的默認(rèn)值,應(yīng)該如此創(chuàng)建Hash:
讓我們再看看:
一個值的改變,不會影響到其他默認(rèn)值。
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方法,它們返回一個數(shù)組。
當(dāng)然還可以使用each_key和each_value方法,顧名思義就是遍歷key和value.
6. Hash可以sort嗎?
ruby的hash實(shí)際是可以sort的,返回一個sort后的二維數(shù)組。
irb(main):028:0> x.sort
=> [[1, 2], [3, 4], [5, 6]]
另外ruby有OrderedHash這個類,它可以讓Hash元素按插入順序來sort,類似于數(shù)組的能力。
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}
當(dāng)然也可以用delete_if帶條件的刪除Hash元素。例如刪除所有Key大于3的:
8. 如何查找Hash元素?
使用has_key?和has_value?來判斷是否有對應(yīng)鍵和值:
irb(main):053:0> x.has_value? 4
=> true
irb(main):054:0> x.has_key? 9
=> false
考慮到默認(rèn)值的情況,不能直接用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. 可以反轉(zhuǎn)Hash嗎?
答案是可以,使用invert方法:
irb(main):012:0> x.invert
=> {6=>5, 2=>1, 4=>3}
10. Hash和數(shù)組如何轉(zhuǎn)換?
Hash轉(zhuǎn)換到數(shù)組很簡單:
數(shù)組轉(zhuǎn)換到Hash麻煩一點(diǎn),自己寫一個方法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的丟值行為?
任何時(shí)候修改了Hash的Key(記住Key是包括數(shù)組在內(nèi)的目標(biāo)),都會發(fā)生丟值行為。
上述修改了鍵x的值,那么這個鍵對應(yīng)的Value就丟失了。
解決辦法是rehash。任何時(shí)候修改了Key的值,都要rehash一次。
標(biāo)簽:西雙版納 克拉瑪依 大慶 甘孜 棗莊 內(nèi)江 河池 南昌
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Ruby中Hash的11個問題解答》,本文關(guān)鍵詞 Ruby,中,Hash,的,11個,問題解答,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。