如果这是一个非常基本的问题,我们深表歉意。我无意中发现asort()
似乎适用于多维数组:
示例PHP
$animals = array(
1 => array('name' => 'Zebra'),
2 => array('name' => 'Fox'),
3 => array('name' => 'Rabbit'),
4 => array('name' => 'Dog'),
5 => array('name' => 'Cat')
);
asort($animals);
var_dump($animals);
输出
array
5 =>
array
'name' => string 'Cat' (length=3)
4 =>
array
'name' => string 'Dog' (length=3)
2 =>
array
'name' => string 'Fox' (length=3)
3 =>
array
'name' => string 'Rabbit' (length=6)
1 =>
array
'name' => string 'Zebra' (length=5)
我想知道为什么这样有效
我认为asort()
只对平面数组进行排序,要对多维数组进行排序需要定义一个自定义排序函数。我在文档中找不到任何解释上述行为的内容。
数组按字典顺序按其值进行比较,因此第一个元素为"cat"的数组小于第一个元素是"zebra"的数组。这只是一种普通的一维排序,恰好用于将数组相互比较。
例如:
php > var_dump(array('a')< array('b'));
bool(true)
php > var_dump(array('a')> array('b'));
bool(false)
这是标准数组比较的转录(PHP)
<?php
// Arrays are compared like this with standard comparison operators
function standard_array_compare($op1, $op2)
{
if (count($op1) < count($op2)) {
return -1; // $op1 < $op2
} elseif (count($op1) > count($op2)) {
return 1; // $op1 > $op2
}
foreach ($op1 as $key => $val) {
if (!array_key_exists($key, $op2)) {
return null; // uncomparable
} elseif ($val < $op2[$key]) {
return -1;
} elseif ($val > $op2[$key]) {
return 1;
}
}
return 0; // $op1 == $op2
}
?>
这与您的案例
PHP根据元素的数量比较数组,例如:具有一个元素的数组将被比较在一起,并首先排序在顶部,然后,PHP查找相似的数组(基于元素的数量),然后相互比较进行排序,依此类推,例如:
array(
a => array(z),
c => array(a,b),
d => array(d,r,3,4),
e => array(h,k,,p)
}
使用asort,结果将是a => array(z)
将是第一个元素,因为没有其他数组包含一个元素,因此,它将被分配在第一位。
array(
c => array(x,b),
e => array(h,k,,p)
a => array(z),
d => array(d,r,3,4),
}