array_merge和array_values重排索引数组性能比较
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了array_merge和array_values重排索引数组性能比较相关的知识,希望对你有一定的参考价值。
###?array_merge?合并一个或多个数组array?**array_merge**?(?array?`$array1`?[,?array?`$...`?]?)
将一个或多个数组的单元合并起来,一个数组中的值附加在前一个数组的后面。返回作为结果的数组。
-?如果输入的数组中有相同的字符串键名,则该键名后面的值将覆盖前一个值。然而,如果数组包含数字键名,后面的值将_不会_覆盖原来的值,而是附加到后面。
-?如果只给了一个数组并且该数组是数字索引的,则键名会以连续方式重新索引。
###?array_values?返回数组中所有的值
array?**array_values**?(?array?`$input`?)
返回?_`input`_?数组中所有的值并给其建立数字索引。
###?对比
两者都可以实现对索引数组的索引值重新排列的操作,方式如下
-?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?);
```
执行结果
```
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]
```
结论
-?不论执行多少次,`array_values`在重新排列索引数组的操作上都比`array_merge`快,只是差距确实不怎么明显
-?语义上`array_values`更清晰一些,毕竟`array_merge`是用来合并数组的
以上是关于array_merge和array_values重排索引数组性能比较的主要内容,如果未能解决你的问题,请参考以下文章
我可以使用连接的 var+array_value 作为 jquery 中的选择器,即 $("#var+array_value")