class DownTime {
public $total, $longest, $count;
}
Run Code Online (Sandbox Code Playgroud)
我有一个关联数组(键是一个id,值是DownTime对象).
我想根据$ total对它进行排序
我已经阅读过PHP:排序数组和stackoverflow上的其他一些问题.
我明白uasort
这样做会很好.但是,作为一种OOP方法,我更喜欢在DownTime类中定义一个特殊函数(如operator<()
在C++中定义,或Comparable.compareTo()
在Java中实现),而不是在调用某个sort函数时传递函数.
您可以在DownTime类上定义compare()方法:
class DownTime {
public $total, $longest, $count;
public static function compare(DownTime $a, DownTime $b) {
// compare $a and $b here, and return -1, 0, 1
}
}
Run Code Online (Sandbox Code Playgroud)
然后像这样使用uasort:
uasort($array, 'DownTime::compare')
Run Code Online (Sandbox Code Playgroud)
PHP中没有这样的"Comparable"接口,但是在useland中实现它会非常简单:
interface Comparable {
function compareTo($a);
}
// a generic compare function
function compare($a, $b) {
if ($a instanceof Comparable) return $a->compareTo($b);
if ($a < $b) return -1;
if ($a > $b) return 1;
return 0;
}
// now you can sort without knowing anything about what the array contains:
uasort($array, 'compare');
Run Code Online (Sandbox Code Playgroud)
如果您希望能够使用ArrayObject透明地执行此操作:
class SortableArrayObject extends ArrayObject
{
function asort() {
return $this->uasort('compare'); // you can even make compare() a member of
// SortableArrayObject and use
// $this->uasort(array($this,'compare'))
}
}
$arrayObject->asort();
Run Code Online (Sandbox Code Playgroud)
在这里,容器对容器一无所知,从OOP的角度来看,这更好.