1

我有一个数组

$users    = array();

$users[0]['id']=1;
$users[0]['name']="user1";

$users[1]['id']=2;
$users[1]['name']="user2";

$users[2]['id']=3;
$users[2]['name']="user3";

我需要将 id 提取到另一个数组 $ids; 这样

$ids[0]=1;
$ids[1]=2;
$ids[2]=3;

我知道一种方法来做到这一点...

$ids    = array();
foreach($users as $user){
   $ids[]  = $user['id'];
}

1.这是最好的方法吗?2.是否可以不循环。3.这是最快的方法吗....?

4

2 回答 2

2

上面的所有评论都很好地解决了这个问题,但由于没有人实际发布任何实际答案,这里有一些额外的信息(为了证明我的回答是合理的):

  • 这是最好的方法吗?

可能,但它肯定是更清洁和最易读的方式

  • 没有循环可以做到吗?

是的,但正如人们所说,这只是一个技巧,因为循环将在后台使用。

  • 这是最快的方法吗?

现在这需要进行一些调查。我使用 100000 个条目重新创建了一个与您类似的数组:

for ($i=0;$i<100000;$i++) {
    $users[] = array('id' => rand(),
            'name' => 'default');
}

并使用不同的案例进行了一些测试:

1.Plain old for 循环(你自己用过的那个):

$ids=array();
$t = microtime(true);
foreach ($users as $key => $value) {
    $ids[] = $value['id'];
} 
echo microtime(true)-$t;

这平均需要 0.085 英寸

2.使用array_walk():

$t = microtime(true);
array_walk($users, create_function('$v,$k,&$ids', '$ids[0][] = $v["id"];'), array(&$ids));
echo microtime(true)-$t;

这平均需要 0.22'' (使用 $GLOBALS['ids'] 而不是这个“参考”黑客时相同)

3.使用splFixedArray:这个迭代器应该比普通数组更快。实际上,上面的代码平均需要 0.075'':

$users = new SplFixedArray(100000);
for ($i=0;$i<100000;$i++) {
    $users[$i] = array('id' => rand(),
            'name' => 'default');
}
$ids=array();
$t = microtime(true);
foreach ($users as $key => $value) {
    $ids[$key] = $value['id'];
}
echo microtime(true)-$t;

下面的代码(我们对两个数组都使用 splFixedArray)执行得更快,大约为 0.062'':

$users = new SplFixedArray(100000);
for ($i=0;$i<100000;$i++) {
    $users[$i] = array('id' => rand(),
            'name' => 'default');
}
$ids=new SplFixedArray(100000);
$t = microtime(true);
foreach ($users as $key => $value) {
    $ids[$key] = $value['id'];
}
echo microtime(true)-$t;

所以,最重要的是,不,这不是最快的方法,但如果你考虑到你在最初的问题中提出的所有 3 个参数,它是最好的

于 2012-08-06T08:45:19.037 回答
0
  • 我认为最好的方式是你作为程序员的方式(但如果你在团队中,那么最好的方式就是团队方式)。
  • 我想我将永远依赖内置的 PHP 函数(某些函数除外)来解决性能问题(因为我认为 PHP 同行会根据需要努力改进它)。
  • 我认为可以在没有循环的情况下做到这一点。
$users = 数组();
$users[0]['id'] = 100;
$users[1]['id'] = 101;
$users[2]['id'] = 102;

$ids = 数组();
array_walk_recursive($users, function($val, $key) use(&$ids){
    if ($key == 'id') $ids[] = $val;
});

print_r($ids);


大批
(
    [0] => 100
    [1] => 101
    [2] => 102
)
于 2012-08-06T13:08:09.137 回答