array_unique(PHP 4 >= 4.0.1)
array_unique -- 移除陣列中重複的值
說明
array array_unique ( array array)
array_unique() 接受 array 作為輸入並返回沒有重複值的新陣列。
注意鍵名保留不變。array_unique() 先將值作為字串排序,然後對每個值只保留第一個遇到的鍵名,接著忽略所有後面的鍵名。這並不意味著在未排序的 array 中同一個值的第一個出現的鍵名會被保留。
注: 當且僅當 (string) $elem1 === (string) $elem2 時兩個單元被認為相同。就是說,當字串的表達一樣時。
第一個單元將被保留。
例子 1. array_unique() 例子
[php]
$input = array ("a" => "green", "red", "b" => "green", "blue", "red");
$result = array_unique ($input);
print_r($result);
?>
[/php]
【拓展閱讀】PHP必須知道的`容易出錯的小細節
注意echo和print的區別
PHP中echo和print都是輸出的作用,但是兩者之間還是有細微的差別。echo輸出後沒有返回值,但print有返回值,當其執行失敗時返回flase。因此可以作為一個普通函式來使用,例如執行$r = print "Hello World"; 變數$r的值將為1。而且程式碼中echo語句的執行效率要略快於print語句。
注意空字串('')和NULL的區別
PHP中空字串和NULL都是以值為0儲存的,但是他們的型別並不一樣,前者是string,而後者是NULL,可見字串('')、NULL值相等但型別不等。
分清==(等於)和===(全等於)的區別
兩者都屬於比較運算子,==(等於)只比較值是否相等,而===(全等於)則不但比較值是否相等,還會比較型別是否相等,它更為嚴格。
分清include與require的區別
include()與require()的功能也基本相同,但在用法上也有一些不同,include()是有條件包含函式,而require()則是無條件包含函式。例如在下面程式碼中,如果變數$a為真,則將包含檔案。而require()則和include()不同,不管$a取何值,下面的程式碼都會把檔案包含,比如:
在錯誤處理方面,使用include語句,如果發生包含錯誤,程式將跳過include語句,雖然會顯示錯誤資訊但是程式還是會繼續執行。但是,require語句會提示一個致命錯誤。
注意isset和 empty的區別
empty是判斷一個變數是否為“空”,而isset則是判斷一個變數是否已經被設定。
分清self :: 和 this--> 的區別
在訪問PHP類中的成員變數或方法時,如果被引用的變數或者方法被宣告成const(常量)或者static(靜態屬性),那麼就必須使用域操作符::,而如果被引用的變數或者方法沒有被宣告成const或者static,那麼就使用指向操作符->。
foreach迴圈後留下懸掛指標
這裡有個問題很多人會迷糊。迴圈結束後,$value並未銷燬,$value其實是陣列中最後一個元素的引用,這樣在後續對$value的使用中,如果不知道這一點,會引發一些莫名奇妙的錯誤:)看看下面這段程式碼:
上面程式碼的執行結果如下:
1,2,3
1,2,3
1,2,2
你猜對了嗎?為什麼是這個結果呢?
我們來分析下。第一個迴圈過後,$value是陣列中最後一個元素的引用。第二個迴圈開始:
第一步:複製$arr[0]到$value(注意此時$value是$arr[2]的引用),這時陣列變成[1,2,1]
第二步:複製$arr[1]到$value,這時陣列變成[1,2,2]
第三步:複製$arr[2]到$value,這時陣列變成[1,2,2]
綜上,最終結果就是1,2,2
避免這種錯誤最好的辦法就是在迴圈後立即用unset函式銷燬變數:
忽略Unicode/UTF-8問題
php程式設計中,在處理非ascii字元時,會遇到一些問題,要很小心的去對待,要不然就會錯誤遍地。舉個簡單的例子,strlen($name),如果$name包含非ascii字元,那結果就有些出乎意料。在此給出一些建議,儘量避免此類問題:
最好使用mb_*函式來處理字串,避免使用老的字串處理函式。這裡要確保PHP的“multibyte”擴充套件已開啟。
資料庫和表最好使用unicode編碼。
知道json_code()函式會轉換非ascii字元,但serialize()函式不會。
php程式碼原始檔最好使用不含bom的utf-8格式。