PHP
数据结构 | Data Structures

Ds\Map::sorted

Ds\Map::sorted

(PECL ds >= 1.0.0)

Ds\Map::sorted — 返回一个副本,按值排序。

描述

public Ds\Map Ds\Map::sorted ([ 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] print_r($map->sorted() ?>

上面的例子会输出类似于:

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] // Reverse $sorted = $map->sorted(function($a, $b) {     return $b <=> $a; } print_r($sorted ?>

上面的例子会输出类似于:

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::sort

Ds\Map::sum →