一、什麼是雜湊
雜湊是一種資料結構,和陣列類似,可以將值存放到其中,或者從中取回值。但是,和陣列不同的是,其索引不是數字,而是名字。也就是說,索引(這裡,我們將它叫key)不是數字而是任意的唯一的字串。
key可以是任意的字串,你可以使用任何的字串作為key,但它們是唯一的。
另一種思考hash 的方法是,把它看作一堆資料(a barrel of data),每乙個資料都有乙個相應的標籤。可以通過標籤訪問此標籤對應的元素。但其中是沒有「第乙個」元素的概念的。在陣列中,陣列元素從0,1,2 開始編號。但在hash中,沒有確定的順序,因此也沒有第乙個元素。只是一些key/value 對的集合。
keys和values均為任意的標量,但keys通常轉換為字串。因此,如果將表示式50/20 作為keys,則其通常被轉換為3字元的字串「2.5」。
由於perl的「沒有不必要的限制」的設計哲學:hash可以是任意大小,從空hash(沒有key/value對),到任何你記憶體允許的大小。
keys是唯一的,但values可以重複。hash的value可以是數字,字串,undef,或者它們的混合,但key是唯一的。
為什麼使用hash
可以把hash看作乙個簡單的資料庫,其中每乙個key下面可以有一塊資料。如果你的任務是關於:「查詢重複的」,「唯一的」,「交叉引用的」,「查詢表」,則hash很可能在這類應用中幫上你的忙。
二、雜湊元素的訪問
要訪問hash 元素,可以使用下面的語法:$hash
這和訪問陣列元素的方法有些類似,這裡下標(key)上使用的是花括號({}),而不是方括號([ ])。現在key 的表示式是字串,而非數字。
hash的名字和perl中其它的識別符號的命名規則是一樣的(字母,數字,下劃線組成,但不能由數字開頭)。
訪問不存在的hash元素將得到undef。
1.作為整體的hash
要引用整個hash,使用百分號(%)作為字首。
為了方便,hash可以轉換為列表,或者反過來。
2.hash 賦值
可以使用如下的語法在hash 之間拷貝:
%new_hash = %old_hash;
將hash轉變成其它形式更加常見。例如,我們可以將hash反**
%inverse_hash = reverse %any_hash;
3.大箭頭符號(=>)
當給hash賦值時,有時並不明顯哪些元素是keys,那些是values,因此發明了大箭頭符號(=>)。在需要逗號的時候,都可以使用大箭頭符號替換。 如:
my %last_name = (
"www" => 1,
"eee" => 2, );
三、雜湊函式
某些有用的函式可以對整個hash 進行操作。
1.keys和values函式
keys函式會返回此hash的所有keys,values函式將返回所有的values。如果hash中沒有元素,則此函式將返回空列表。
my %hash = ("a"=>1, "b"=>2, "c"=>3);
print my @k = keys %hash;
print my @v = values %hash;
2.each函式
如果想迭代hash的每乙個元素,一種通常的方法是使用each函式,它將返回key/value對應的2個元素列表。
my %hash = ("a"=>1, "b"=>2, "c"=>3);
while(($key, $value) = each %hash)
當然,each返回的key/vlaue對,順序是混亂的(它其順序和keys和values函式返回的順序相同)。如果想將其按序排放,可以對它們排序(使用sort)。
my %hash = ("a"=>1, "b"=>2, "c"=>3, "d"=>4);
foreach $key (sort keys %hash) ;
print "$key => $value/n"; }
四、雜湊的通常用法
1.exists函式
要檢視hash中是否存在某個key,可以使用exists函式,如果hash中存在此key,則返回true,與是否有對應的value無關。
my %hash = ("a"=>1, "b"=>2, "c"=>3, "d"=>4);
if(exists $hash)
2.delete 函式
delete函式將某個給定的key(包括其對應的value)從hash中刪除。如果不存在這個key,則什麼也不做,不會有警告或者錯誤資訊。
my %hash = ("a"=>1, "b"=>2, "c"=>3, "d"=>4);
delete $hash;
foreach $key (sort keys %hash) ;
print "$key => $value/n"; }
3.hash 元素的內插
你可以在雙引號的字串中使用單個hash元素,但不支援整個hash 的內插。
my %hash = ("a"=>1, "b"=>2, "c"=>3, "d"=>4);
foreach $key (sort keys %hash)
/n"; }
Perl基礎學習02之陣列和雜湊
目錄 陣列 arrays 陣列定義 陣列元素連線 陣列長度,方法一 陣列長度,方法二 遍歷陣列,方法一 遍歷陣列,方法二 陣列末尾增加元素 push 陣列末尾刪除元素 pop 陣列開頭增加元素 unshift 陣列開頭刪除元素 shift 顛倒陣列元素順序 reverse 陣列元素排序,sort,不...
perl學習日記6雜湊
思考hash 的方法是,把它看作一堆資料 a barrel of data 參見圖6 2 每乙個資料都有乙個相應的標籤。可以通過標籤訪問此標籤對應的元素。但其中是沒有 第乙個 元素的概念的。在陣列中,陣列元素從0,1 2 開始編號。但在hash 中,沒有確定的順序,因此也沒有第乙個元素。只是一些ke...
perl 雜湊 hash 學習筆記( )
1.什麼是雜湊 雜湊是perl的一種資料型別,比較類似陣列,用於存放資料,包括2部分關鍵字keys和值value。不同於陣列,雜湊訪問元素的是按照名字訪問標量的key value.hash 用 來標示 2.hash 操作 a.增加 my hash 定義 第一種寫法 hash young author...