php的array,和java是有很大差距的,雖然php的弱類型的設計可能會被很多java、C++的程序員诟病,但是我覺得在數組容器的設計上,php走的比java和C++都要遠。
java的容器設計除了不徹底的問題,其允許存在類C++的數組的存在,是java語言本身唯一一處不滿足一切皆對象的存在。
實際上容器的存在,本身是要降低一定的效率的,可是如果過分強調效率,為什麼不干脆使用機器碼呢?所以我不太喜歡那些拿php容器設計走的過分遠的觀點。
眾所周知,php的array本身是map。
對於普通數組而言,實際上其內部結構是:
$arr1=array(1,2,3,4,5); print_r($arr1,1); Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 )
而對於我們通常理解的map而言,php內部是這麼實現的:
$arr2=array('c'=>1,'y'=>2,'m'=>3); print_r($arr2,1); Array ( [c] => 1 [y] => 2 [m] => 3 )
對於數組合並而言,你可以認為php使用了類似於C++的重載功能,重載了加號:
print_r($arr1+$arr2,1); Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 [c] => 1 [y] => 2 [m] => 3 )
這種數組合並很方便於你從頭遍歷這個數組,因為在很多時候你不會采用隨機訪問的方式使用數組,而是從頭遍歷到結尾。
不過,這裡,你容易忽略的一個問題是,array本質就是map。如果兩個數組有相同鍵的時候,是很容易被你忽略的:
$arr1=array(1,2,3,4,5); $arr2=array(7,8,9); $arr3=array('1'=>'c','2'=>'y','3'=>'m','4'=>'z','5'=>'a');
print_r($arr1+$arr2,1);
print_r($arr1+$arr3,1);
Array (
[0] => 1
[1] => 2
[2] => 3
[3] => 4
[4] => 5
) Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5
[5] => a
)
我舉第二個例子的意思就是告訴你,缺省的時候,php的鍵是0,1,2,3。
而對於數組合並的時候,對於已經存在的鍵,後面追加的值不會覆蓋原來的值。
似乎只有最後一句話的價值比較大。我寫博客就是廢話比較多。