ArrayObject::uasort

(PHP 5 >= 5.2.0, PHP 7, PHP 8)

ArrayObject::uasort使用用户定义的比较函数排序条目并保持键关联

说明

public ArrayObject::uasort(callable $callback): true

此函数使用用户定义的比较函数排序条目,使键保持与其关联的条目的关联。

这主要用于对关联数组进行排序,其中实际元素顺序很重要。

注意:

如果两个成员比较相等,则保留其原始顺序。在 PHP 8.0.0 之前,它们在排序数组中的相对顺序是不确定的。

参数

callback

比较函数必须返回一个小于、等于或大于零的整数,如果第一个参数分别被认为小于、等于或大于第二个参数。

callback(mixed $a, mixed $b): int
警告

从比较函数返回 *非整数* 值,例如 float,会导致回调返回值内部强制转换为 int。因此,诸如 0.990.1 之类的值都将被强制转换为整数 0,这将比较这些值是否相等。

返回值

始终返回 true

变更日志

版本 说明
8.2.0 返回值现在为 true;之前是 bool

范例

示例 #1 ArrayObject::uasort() 示例

<?php
// 比较函数
function cmp($a, $b) {
if (
$a == $b) {
return
0;
}
return (
$a < $b) ? -1 : 1;
}

// 要排序的数组
$array = array('a' => 4, 'b' => 8, 'c' => -1, 'd' => -9, 'e' => 2, 'f' => 5, 'g' => 3, 'h' => -4);
$arrayObject = new ArrayObject($array);
print_r($arrayObject);

// 排序并打印结果数组
$arrayObject->uasort('cmp');
print_r($arrayObject);
?>

上面的示例将输出

Array
(
    [a] => 4
    [b] => 8
    [c] => -1
    [d] => -9
    [e] => 2
    [f] => 5
    [g] => 3
    [h] => -4
)
Array
(
    [d] => -9
    [h] => -4
    [c] => -1
    [e] => 2
    [g] => 3
    [a] => 4
    [f] => 5
    [b] => 8
)

参见

添加说明

用户贡献的说明 1 个说明

1
poxetinho at gmail dot com
12 年前
请注意,(-1, 1) 之间的返回值被视为 0。
To Top