Ds\Map::sort
Ds\Map::sort
(PECL ds >= 1.0.0)
Ds\Map::sort — 按照值对地图进行排序。
描述
public void Ds\Map::sort ([ callable $comparator ] )
使用可选comparator
功能按值对地图进行排序。
参数
comparator
如果第一个参数分别小于,等于或大于第二个参数,则比较函数必须返回小于,等于或大于零的整数。请注意,在PHP 7.0.0之前,此整数必须在-2147483648到2147483647之间。
int callback ( mixed $a, mixed $b )
警告
从比较函数返回非整
数值(如float)将导致内部转换为回调的返回值的整数。因此,诸如0.99和0.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
)
)
← Ds\Map::slice
Ds\Map::sorted →