国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

PHP中關聯數組的用法詳解

2024-09-04 11:46:18
字體:
來源:轉載
供稿:網友

php中關聯數據用法與一些關聯數組的一些小技巧,包括添加,刪除,編輯,遍歷,交換鍵和值,排序,查詢等等關聯數組的一些實例.

1、添加數組元素

PHP是一種弱類型語言,這意味著你不需要顯示聲明一個數組及其大小,相反,你可以同時聲明并填充數組,代碼如下:

  1. $capitals = array(   
  2.   'Alabama' => 'Montgomery',   
  3.   'Alaska'  => 'Juneau',   
  4.   'Arizona' => 'Phoenix'   
  5. ); 

額外的數組元素可以象下面這樣追加:

$capitals['Arkansas'] = 'Little Rock'; 如果你正在處理數字索引數組,你可能想使用顯示命名的函數前置和追加元素,如array_push()和array_unshift()函數,但這些函數不能操作關聯數組.

2、刪除數組元素

如果要從數組中刪除一個元素,請使用unset()函數,代碼如下:

unset($capitals['California']);  

使用數字索引數組時,刪除數組元素的辦法更多,更靈活,可以使用array_shift()和array_pop()函數分別從數組的開頭和末尾刪除一個元素.

3、交換鍵和值

假設你想創建一個名叫$states的新數組,使用州府作為索引,使用州名作為關聯值,使用array_flip()函數很容易完成這個任務,代碼如下:

  1. $capitals = array(   
  2.   'Alabama' => 'Montgomery',   
  3.   'Alaska'  => 'Juneau',   
  4.   'Arizona' => 'Phoenix'   
  5. );   
  6. $states = array_flip($capitals);   
  7. // $states = array(   
  8. //  'Montgomery' => string 'Alabama',   
  9. //  'Juneau'     => string 'Alaska',   
  10. //  'Phoenix'    => string 'Arizona'   
  11. // ); 

4、合并數組

假設前面的數組由一個基于Web的“FlashCard”服務使用,你想提供一種方法測試學生對美國各州首府的掌握情況,你可以使用array_merge()函數合并包含州和首府的數組,代碼如下:

  1. $stateCapitals = array(   
  2.   'Alabama' => 'Montgomery',   
  3.   'Alaska'  => 'Juneau',   
  4.   'Arizona' => 'Phoenix'   
  5. );   
  6. $countryCapitals = array (   
  7.   'Australia' => 'Canberra',   
  8.   'Austria'   => 'Vienna',   
  9.   'Algeria'   => 'Algiers'   
  10. );   
  11. $capitals = array_merge($stateCapitals$countryCapitals);  

5、編輯數組值

假設在數組中的數據包含大小寫錯誤,在插入到數據庫之前,你想糾正這些錯誤,你可以使用array_map()函數給每個數組元素應用一個回調,代碼如下:

  1. function capitalize($element)   
  2. {   
  3.   $element = strtolower($element);   
  4.   return ucwords($element);   
  5. }   
  6. $capitals = array(   
  7.   'Alabama' => 'montGoMEry',   
  8.   'Alaska'  => 'Juneau',   
  9.   'Arizona' => 'phoeniX'   
  10. );   
  11. $capitals = array_map("capitalize"$capitals);  

6、按鍵對數組排序

FlashCard程序常常使用各種排序,如按字母順序排序,你可以使用ksort()函數按鍵對關聯數組進行排序,代碼如下:

  1. $capitals = array(   
  2.   'Arizona' => 'Phoenix',   
  3.   'Alaska'  => 'Juneau',   
  4.   'Alabama' => 'Montgomery'   
  5. );   
  6. ksort($capitals); 

因為數組是通過參數傳遞給ksort()函數的,意味著你不再需要將排序結果分配給另一個變量.

7、隨機數組排序

在FlashCard程序中還涉及到另一種隨機排序技術,這時你要使用shuffle()函數實現數組項目的隨機排序,代碼如下:

  1. $capitals = array(   
  2.   'Arizona' => 'Phoenix',   
  3.   'Alaska'  => 'Juneau',   
  4.   'Alabama' => 'Montgomery'   
  5. );   
  6. shuffle($capitals); 

如果不需要打亂數組順序,你只是想隨機選擇一個值,那么使用array_rand()函數即可.

8、確定鍵和值是否存在

你可以使用in_array()函數確定一個數組元素是否存在,代碼如下:

  1. $capitals = array(   
  2.   'Arizona' => 'Phoenix',   
  3.   'Alaska'  => 'Juneau',   
  4.   'Alabama' => 'Montgomery'   
  5. );   
  6. if (in_array("Juneau"$capitals))   
  7. {   
  8.   echo "Exists!";   
  9. else {   
  10.   echo "Does not exist!";   

很少有人知道這個函數也可以確定一個數組鍵是否存在,在這一點上,它和array_key_exists()函數的功能一樣,代碼如下:

  1. $capitals = array(   
  2.   'Arizona' => 'Phoenix',   
  3.   'Alaska'  => 'Juneau',   
  4.   'Alabama' => 'Montgomery'   
  5. );   
  6. if (array_key_exists("Alaska"$capitals))   
  7. {   
  8.   echo "Key exists!";   
  9. else {   
  10.   echo "Key does not exist!";   

9、搜索數組

你可能想搜索數組資源,這樣用戶就可以方便地用一個特定的州府檢索關聯的州,可以通過array_search()函數實現數組搜索,代碼如下:

  1. $capitals = array(   
  2.   'Arizona' => 'Phoenix',   
  3.   'Alaska'  => 'Juneau',   
  4.   'Alabama' => 'Montgomery'   
  5. );   
  6. $state = array_search('Juneau'$capitals);   
  7. // $state = 'Alaska' 

10、標準PHP庫

標準PHP庫(Standard PHP Library,SPL)為開發人員提供了許多數據結構,迭代器,接口,異常和其它以前PHP語言沒有的功能,使用這些功能可以通過面向對象的語法遍歷數組,代碼如下:

  1. $capitals = array(   
  2.   'Arizona' => 'Phoenix',   
  3.   'Alaska'  => 'Juneau',   
  4.   'Alabama' => 'Montgomery'   
  5. );   
  6. $arrayObject = new ArrayObject($capitals);   
  7. foreach ($arrayObject as $state => $capital)   
  8. {   
  9.   printf("The capital of %s is %s<br />"$state$capital);   
  10. }   
  11. // The capital of Arizona is Phoenix   
  12. // The capital of Alaska is Juneau   
  13. // The capital of Alabama is Montgomery 

遍歷關聯數組的三種方法:

foreach,代碼如下:

  1. <?php 
  2. $sports = array
  3.     'football' => 'good'
  4.     'swimming' => 'very well'
  5.     'running'  => 'not good' 
  6.  ); 
  7.  
  8. foreach ($sports as $key => $value) { 
  9.     echo $key.": ".$value."<br />"
  10. ?> 
  11. /* 
  12. 程序運行結果: 
  13. football: good 
  14. swimming: very well 
  15.  running: not good 
  16. */ 

each,代碼如下:

  1. <?php 
  2. $sports = array
  3.     'football' => 'good'
  4.     'swimming' => 'very well'
  5.     'running'  => 'not good' 
  6.  ); 
  7.  
  8. while ($elem = each($sports)) { 
  9.     echo $elem['key'].": ".$elem['value']."<br />"
  10. ?> 
  11. /* 
  12. 程序運行結果: 
  13. football: good 
  14. swimming: very well 
  15. running: not good 
  16. */ 

list & each,代碼如下:

  1. <?php 
  2. $sports = array
  3.     'football' => 'good'
  4.     'swimming' => 'very well'
  5.     'running'  => 'not good' 
  6.  ); 
  7.  
  8. while (list($key$value) = each($sports)) { 
  9.     echo $key.": ".$value."<br />"
  10. ?> 
  11. /* 
  12. 程序運行結果: 
  13. football: good 
  14. swimming: very well 
  15. running: not good 
  16. */ 

哈希表== Hash Table

有一份用戶名列表,存儲了 10000 個用戶名,沒有重復項;

還有一份黑名單列表,存儲了 2000 個用戶名,格式與用戶名列表相同;

現在需要從用戶名列表中刪除處在黑名單里的用戶名,要求用盡量快的時間處理.

這個問題是一個小規模的處理量,如果實際一點,2 個表都可能很大,比如有 2 億條記錄.

我最開始想到的方法,就是做一個嵌套的循環,設用戶名表有 M 條記錄,黑名單列表有 N 條記錄,那么,循環的次數是 M * N 次.

PHP 版代碼:

  1. <?php 
  2. foreach($arrayM as $keyM => $nameM) { 
  3.    foreach($arrayN as $nameN) { 
  4.    if ($nameM == $nameN) { 
  5.    // 本行執行了 M * N 次! 
  6.    unset($arrayM[$keyM]); 
  7.    } 
  8.    } 
  9. return $arrayM
  10. ?> 

另一種方式,利用數組索引.

PHP 是一種弱類型的語言,不像 C 語言那樣有嚴格的變量類型限制,C 語言的數組,每一個元素的類型必須一致,而且索引都是從 0 開始.

PHP 的數組,可以用字符串作為索引,也稱為關聯數組.

數組索引,有一個天然的限制就是不會重復,而且訪問的時候不需要查找,可以直接定位.

還是剛才的那個問題,我們采用另一種辦法,把黑名單列表的用戶名組織到一個數組里,數組的索引就是用戶名,然后,遍歷用戶列表的時候,只需直接用 isset 查詢那個用戶名是否存在即可,代碼如下:

  1. <?php 
  2. $arrayHash = array(); 
  3. foreach($arrayN as $nameN) { 
  4.    // 本行執行了 N 次。 
  5.    $arrayHash[$nameN] = 1; 
  6. foreach($arrayM as $keyM => $nameM) { 
  7.    if (isset($arrayHash[$nameM])) { 
  8.    // 本行執行了 M 次! 
  9.    unset($arrayM[$keyM]); 
  10.    } 
  11. return $arrayM
  12. ?> 

可以看到,優化過的代碼,循環次數是 M + N 次.

假如 M 和 N 都是 10000,優化前,循環了 1 億次,優化后,只循環了 20000 次,差了 5000 倍,如果第二個程序耗時 1 秒,則第一個程序需要將近一個半小時.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 三都| 星子县| SHOW| 江津市| 太仆寺旗| 万载县| 手游| 东乡县| 宣化县| 黄大仙区| 温泉县| 武宣县| 靖宇县| 枞阳县| 佛山市| 丁青县| 盘锦市| 吉林省| 鹤壁市| 额尔古纳市| 宝丰县| 荥阳市| 名山县| 许昌市| 怀宁县| 离岛区| 壤塘县| 平潭县| 南投市| 古蔺县| 北海市| 双鸭山市| 额敏县| 托克逊县| 昭苏县| 定远县| 府谷县| 天峨县| 昌江| 正阳县| 和硕县|