Perl Hash用法之入門教程

2021-06-16 16:18:43 字數 3006 閱讀 4753

**:

本文和大家重點討論一下perl hash的用法,雜湊是一種資料結構,和陣列類似,但是,和陣列不同的是,其索引不是數字,而是名字。也就是說,索引(這裡,我們將它叫key)不是數字而是任意的唯一的字串。

雜湊是一種資料結構,和陣列類似,可以將值存放到其中,或者從中取回值。但是,和陣列不同的是,其索引不是數字,而是名字。也就是說,索引(這裡,我們將它叫key)不是數字而是任意的唯一的字串。

key可以是任意的字串,你可以使用任何的字串作為key,但它們是唯一的。

另一種思考hash 的方法是,把它看作一堆資料(a barrel of data),每乙個資料都有乙個相應的標籤。可以通過標籤訪問此標籤對應的元素。但其中是沒有「第乙個」元素的概念的。在陣列中,陣列元素從0,perl學習之雜湊hash_馬亮的計算機技術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是唯一的。

為什麼使用perl hash

可以把hash看作乙個簡單的資料庫,其中每乙個key下面可以有一塊資料。如果你的任務是關於:「查詢重複的」,「唯一的」,「交叉引用的」,「查詢表」,則hash很可能在這類應用中幫上perl學習之雜湊hash_馬亮的計算機技術你的忙。

要訪問hash 元素,可以使用下面的語法:$hash

這和訪問陣列元素的方法有些類似,這裡下標(key)上使用的是花括號({}),而不是方括號([ ])。現在key 的表示式是字串,而非數字。

hash的名字和perl中其它的識別符號的命名規則是一樣的(字母,數字,下劃線組成,但不能由數字開頭)。

訪問不存在的hash元素將得到undef。

1.作為整體的perl hash

要引用整個hash,使用百分號(%)作為字首。

為了方便,hash可以轉換為列表,或者反過來。

2.perl hash賦值

可以使用如下的語法在hash 之間拷貝:

%new_hash = %old_hash;

將hash轉變成其它形式更加常見。例如,我們可以將hash反**

%inverse_hash = reverse %any_hash;

3.大箭頭符號(=>)

當給hash賦值時,有時並不明顯哪些元素是keys,那些是values,因此發明了大箭頭符號(=>)。在需要逗號的時候,都可以使用大箭頭符號替換。

如:某些有用的函式可以對整個hash 進行操作。

my %last_name = 

( "www" => 1,

"eee" => 2,

);

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個元素列表。

當對同乙個hash 函式進行一次迭代時,將返回下乙個key/value對,直到所有的元素均被訪問。如果沒有更多的key/value對,則each函式將返回空表。

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.perl hash 元素的內插

你可以在雙引號的字串中使用單個hash元素,但不支援整個hash 的內插。

my %hash = ("a"=>1, "b"=>2, "c"=>3, "d"=>4);  

foreach $key (sort keys %hash)

\n";

}

Perl 雜湊Hash用法之入門教程

一 什麼是perl hash 雜湊是一種資料結構,和陣列類似,可以將值存放到其中,或者從中取回值。但是,和陣列不同的是,其索引不是數字,而是名字。也就是說,索引 這裡,我們將它叫key 不是數字而是任意的唯一的字串。key可以是任意的字串,你可以使用任何的字串作為key,但它們是唯一的。另一種思考h...

wxPython之Boa IDE入門教程

最近開發一款小軟體,找到了wxpython這個東東,感覺還不錯就是sizer神馬的用起來有點費勁,主要原因是剛開始不了解各個引數的意義,於是找到了boa這個神器,起碼短期內解決了我的問題。總體而言,boa可以作為wxpython入門的利器之一。首先,boa更適合執行與windows環境下,在linu...

php之socket入門教程

socket是應用層與tcp ip協議族通訊的中間軟體抽象層,它是一組介面。在設計模式中,socket其實就是乙個門面模式,它把複雜的tcp ip協議族隱藏在socket介面後面,對使用者來說,一組簡單的介面就是全部,讓socket去組織資料,以符合指定的協議。基本步驟 echo server r ...