5

これが本当に基本的な質問である場合はお詫び申し上げます。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()、多次元配列をソートするには、カスタムソート関数を定義する必要がありました。上記の動作を説明するドキュメントには何も見つかりません。

4

3 に答える 3

7

配列は値によって辞書式順序で比較されるため、最初の要素が「cat」である配列は、最初の要素が「zebra」である配列よりも小さくなります。これは、たまたま配列を相互に比較する通常の 1 次元の並べ替えです。

例えば:

php > var_dump(array('a')< array('b'));
bool(true)
php > var_dump(array('a')> array('b'));
bool(false)
于 2013-07-12T11:47:51.630 に答える
3

これは、標準的な配列比較 (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
}
?>

それはあなたのケースと一貫しています

于 2013-07-12T11:57:14.953 に答える