Ds\Map::sort

(PECL ds >= 1.0.0)

Ds\Map::sort 按值对映射进行就地排序

说明

public Ds\Map::sort(callable $comparator = ?): void

按值对映射进行就地排序,使用可选的 comparator 函数。

参数

comparator

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

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

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

返回值

不返回值。

示例

示例 #1 Ds\Map::sort() 示例

<?php
$map
= new \Ds\Map(["a" => 2, "b" => 3, "c" => 1]);
$map->sort();

print_r($map);
?>

上面的示例将输出类似于以下内容

Ds\Map Object
(
    [0] => Ds\Pair Object
        (
            [key] => c
            [value] => 1
        )

    [1] => Ds\Pair Object
        (
            [key] => a
            [value] => 2
        )

    [2] => Ds\Pair Object
        (
            [key] => b
            [value] => 3
        )

)

示例 #2 Ds\Map::sort() 使用比较器的示例

<?php
$map
= new \Ds\Map(["a" => 2, "b" => 3, "c" => 1]);

$map->sort(function($a, $b) {
return
$b <=> $a;
});

print_r($map);
?>

上面的示例将输出类似于以下内容

Ds\Map Object
(
    [0] => Ds\Pair Object
        (
            [key] => b
            [value] => 3
        )

    [1] => Ds\Pair Object
        (
            [key] => a
            [value] => 2
        )

    [2] => Ds\Pair Object
        (
            [key] => c
            [value] => 1
        )

)
添加注释

用户贡献的注释

此页面没有用户贡献的注释。
To Top