array_merge 合并一個(gè)或多個(gè)數(shù)組
array array_merge ( array $array1
[, array $...
] )
將一個(gè)或多個(gè)數(shù)組的單元合并起來(lái),一個(gè)數(shù)組中的值附加在前一個(gè)數(shù)組的后面。返回作為結(jié)果的數(shù)組。
如果輸入的數(shù)組中有相同的字符串鍵名,則該鍵名后面的值將覆蓋前一個(gè)值。然而,如果數(shù)組包含數(shù)字鍵名,后面的值將不會(huì)覆蓋原來(lái)的值,而是附加到后面。
如果只給了一個(gè)數(shù)組并且該數(shù)組是數(shù)字索引的,則鍵名會(huì)以連續(xù)方式重新索引。
array_values 返回?cái)?shù)組中所有的值
array array_values ( array $input
)
返回 input
數(shù)組中所有的值并給其建立數(shù)字索引。
對(duì)比
兩者都可以實(shí)現(xiàn)對(duì)索引數(shù)組的索引值重新排列的操作,方式如下
- array_merge
array_merge( $array, [] )
- array_values
array_values( $array )
性能比較
$a = $b = [
'1' => '2',
'2' => '2',
'3' => '2',
'4' => '2',
'5' => '2',
'6' => '2',
'7' => '2',
'8' => '2',
'9' => '2',
'10' => '2',
];
$begin = microtime( true );
for ( $i = 1; $i <= 1000000; $i++ ) {
$m = array_merge( $a, [ ] );
}
$end1 = microtime( true );
echo ($end1 - $begin), ':';
print_r( $m );
$a = $b;
for ( $i = 1; $i <= 1000000; $i++ ) {
$m = array_values( $a );
}
$end2 = microtime( true );
echo ($end2 - $end1), ':';
print_r( $m );
執(zhí)行結(jié)果
3.3471908569336:Array
(
[0] => 2
[1] => 2
[2] => 2
[3] => 2
[4] => 2
[5] => 2
[6] => 2
[7] => 2
[8] => 2
[9] => 2
)
2.975170135498:Array
(
[0] => 2
[1] => 2
[2] => 2
[3] => 2
[4] => 2
[5] => 2
[6] => 2
[7] => 2
[8] => 2
[9] => 2
)
[Finished in 6.4s]
結(jié)論
不論執(zhí)行多少次,
array_values
在重新排列索引數(shù)組的操作上都比array_merge
快,只是差距確實(shí)不怎么明顯語(yǔ)義上
array_values
更清晰一些,畢竟array_merge
是用來(lái)合并數(shù)組的