Ruby 哈希(Hash)
哈希(Hash)是類似"key" => "value" 這樣的鍵值對集合。 哈希類似於一個數組,只不過它的索引不局限於使用數字。
Hash 的索引(或者叫"鍵")幾乎可以是任何對象。
Hash 雖然和數組類似,但卻有一個很重要的區別:Hash 的元素沒有特定的順序。 如果順序很重要的話就要使用數組了。
創建哈希
與數組一樣,有各種不同的方式來創建哈希。 您可以通過new類方法創建一個空的哈希:
months = Hash.new
您也可以使用new創建帶有默認值的哈希,不帶默認值的哈希是nil :
months = Hash.new( "month" ) 或 months = Hash.new "month"
當您訪問帶有默認值的哈希中的任意鍵時,如果鍵或值不存在,訪問哈希將返回默認值:
#!/usr/bin/ruby months = Hash.new( "month" ) puts "#{months[0]}" puts "#{months[72]}"
以上實例運行輸出結果為:
month month
#!/usr/bin/ruby H = Hash["a" => 100, "b" => 200] puts "#{H['a']}" puts "#{H['b']}"
以上實例運行輸出結果為:
100 200
您可以使用任何的Ruby 對像作為鍵或值,甚至可以使用數組,如下實例所示:
[1,"jan"] => "January"
哈希內置方法
如果需要調用Hash 方法,需要先實例化一個Hash 對象。 下面是創建Hash 對象實例的方式:
Hash[[key =>|, value]* ] or Hash.new [or] Hash.new(obj) [or] Hash.new { |hash, key| block }
這將返回一個使用給定對象進行填充的新的哈希。 現在,使用創建的對象,我們可以調用任意可用的方法。 例如:
#!/usr/bin/ruby $, = ", " months = Hash.new( "month" ) months = {"1" => "January", "2" => "February"} keys = months.keys puts "#{keys}"
以上實例運行輸出結果為:
["1", "2"]
下面是公共的哈希方法(假設hash是一個Hash對象):
序號 | 方法& 描述 |
---|---|
1 | hash == other_hash 檢查兩個哈希是否具有相同的鍵值對個數,鍵值對是否相互匹配,來判斷兩個哈希是否相等。 |
2 | hash.[key] 使用鍵,從哈希引用值。 如果未找到鍵,則返回默認值。 |
3 | hash.[key]=value 把value給定的值與key給定的鍵進行關聯。 |
4 | hash.clear 從哈希中移除所有的鍵值對。 |
5 | hash.default(key = nil) 返回hash的默認值,如果未通過default=進行設置,則返回nil。 (如果鍵在hash中不存在,則[]返回一個默認值。) |
6 | hash.default = obj 為hash設置默認值。 |
7 | hash.default_proc 如果hash通過塊來創建,則返回塊。 |
8 | hash.delete(key) [or] array.delete(key) { |key| block } 通過key從hash中刪除鍵值對。 如果使用了塊且未找到匹配的鍵值對,則返回塊的結果。 把它與delete_if進行比較。 |
9 | hash.delete_if { |key,value| block } 為block為true的每個塊,從hash中刪除鍵值對。 |
10 | hash.each { |key,value| block } 遍歷hash ,為每個key調用一次block,傳遞key-value作為一個二元素數組。 |
11 | hash.each_key { |key| block } 遍歷hash ,為每個key調用一次block,傳遞key作為參數。 |
12 | hash.each_key { |key_value_array| block } 遍歷hash ,為每個key調用一次block,傳遞key和value作為參數。 |
13 | hash.each_value { |value| block } 遍歷hash ,為每個key調用一次block,傳遞value作為參數。 |
14 | hash.empty? 檢查hash是否為空(不包含鍵值對),返回true或false 。 |
15 | hash.fetch(key [, default] ) [or] hash.fetch(key) { | key | block } 通過給定的key從hash返回值。 如果未找到key ,且未提供其他參數,則拋出IndexError異常;如果給出了default ,則返回default ;如果指定了可選的block,則返回block的結果。 |
16 | hash.has_key?(key) [or] hash.include?(key) [or] hash.key?(key) [or] hash.member?(key) 檢查給定的key是否存在於哈希中,返回true或false 。 |
17 | hash.has_value?(value) 檢查哈希是否包含給定的value 。 |
18 | hash.index(value) 為給定的value返回哈希中的key ,如果未找到匹配值則返回nil 。 |
19 | hash.indexes(keys) 返回一個新的數組,由給定的鍵的值組成。 找不到的鍵將插入默認值。 該方法已被廢棄,請使用select。 |
20 | hash.indices(keys) 返回一個新的數組,由給定的鍵的值組成。 找不到的鍵將插入默認值。 該方法已被廢棄,請使用select。 |
21 | hash.inspect 返回哈希的打印字符串版本。 |
22 | hash.invert 創建一個新的hash ,倒置hash中的keys和values 。 也就是說,在新的哈希中,hash中的鍵將變成值,值將變成鍵。 |
23 | hash.keys 創建一個新的數組,帶有hash中的鍵。 /td> |
24 | hash.length 以整數形式返回hash的大小或長度。 |
25 | hash.merge(other_hash) [or] hash.merge(other_hash) { |key, oldval, newval| block } 返回一個新的哈希,包含hash和other_hash的內容,重寫hash中與other_hash帶有重複鍵的鍵值對。 |
26 | hash.merge!(other_hash) [or] hash.merge!(other_hash) { |key, oldval, newval| block } 與merge 相同,但實際上hash 發生了變化。 |
27 | hash.rehash 基於每個key的當前值重新建立hash。 如果插入後值發生了改變,該方法會重新索引hash 。 |
28 | hash.reject { |key, value| block } 為block為true的每個鍵值對創建一個新的hash 。 |
29 | hash.reject! { |key, value| block } 與reject相同,但實際上hash發生了變化。 |
30 | hash.replace(other_hash) 把hash的內容替換為other_hash的內容。 |
31 | hash.select { |key, value| block } 返回一個新的數組,由block返回true的hash中的鍵值對組成。 |
32 | hash.shift 從hash中移除一個鍵值對,並把該鍵值對作為二元素數組返回。 |
33 | hash.size 以整數形式返回hash的size或length。 |
34 | hash.sort 把hash轉換為一個包含鍵值對數組的二維數組,然後進行排序。 |
35 | hash.store(key, value) 存儲hash中的一個鍵值對。 |
36 | hash.to_a 從hash 中創建一個二維數組。 每個鍵值對轉換為一個數組,所有這些數組都存儲在一個數組中。 |
37 | hash.to_hash 返回hash (self)。 |
38 | hash.to_s 把hash轉換為一個數組,然後把該數組轉換為一個字符串。 |
39 | hash.update(other_hash) [or] hash.update(other_hash) {|key, oldval, newval| block} 返回一個新的哈希,包含hash和other_hash的內容,重寫hash中與other_hash帶有重複鍵的鍵值對。 |
40 | hash.value?(value) 檢查hash是否包含給定的value 。 |
41 | hash.values 返回一個新的數組,包含hash的所有值。 |
42 | hash.values_at(obj, ...) 返回一個新的數組,包含hash中與給定的鍵相關的值。 |