普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头取出。在优先队列中,元素被赋予优先级。当访问元素时,具有最高优先级的元素最先取出。优先队列具有最高级先出 (largest-in,first-out)的行为特征。
总结下来就是普通队列有**先进先出**原则,优先级队列有**优先级高先出**原则,这个优先级可以设置;
## 类摘要
```php
// 1. 没有实现ArrayAccess接口,所以不能像数组那样操作;
SplPriorityQueue implements Iterator , Countable {
/* 方法 */
public __construct ( void )
// 比较方法,内部应该用到了冒泡排序,对于权重值来说,返回0代表相等,返回正整数就代表大于,返回负整数就代表小于;
// 默认是权重值越优先,也可以让其被子类覆盖改为权重值越小越优先
public int compare ( mixed $priority1 , mixed $priority2 )
public mixed extract ( void )
//恢复到上一个被破坏的节点? 测试无用;
public void recoverFromCorruption ( void )
public void setExtractFlags ( int $flags )
public void insert ( mixed $value , mixed $priority )
public int count ( void )
public mixed current ( void )
public bool isEmpty ( void )
public mixed key ( void )
public void next ( void )
public void rewind ( void )
public mixed top ( void )
public bool valid ( void )
}
```
## Example
```php
class PQtest extends SplPriorityQueue
{
//覆盖父类,更改其优先规则为权重值越小越优先;
public function compare($priority1, $priority2)
{
if ($priority1 === $priority2) return 0;
return $priority1 > $priority2 ? -1 : 1;
}
}
$pq = new PQtest();
// 设置值与优先值
$pq->insert('a', 10);
$pq->insert('b', 1);
$pq->insert('c', 8);
/**
* 设置元素出队模式
* SplPriorityQueue::EXTR_DATA 仅提取值
* SplPriorityQueue::EXTR_PRIORITY 仅提取优先级
* SplPriorityQueue::EXTR_BOTH 提取数组包含值和优先级
*/
$pq->setExtractFlags(PQtest::EXTR_BOTH);
//从顶部取出一个节点,该节点下面的节点移上为顶部节点;
print_r(
$pq->extract()
);
/*
[data] => b
[priority] => 1
*/
$pq->recoverFromCorruption();
//拿出顶部节点
print_r(
$pq->extract()
);
/*
[data] => c
[priority] => 8
*/
// 还原自上一个节点? 没什么效果?
$pq->recoverFromCorruption();
print_r(
$pq->current()
);
$pq->rewind();
while($pq->valid()){
print_r($pq->current());
echo PHP_EOL;
$pq -> next();
}
```
- 现代化PHP特性
- php7常用特性整理
- 反射机制Reflection
- 依赖注入与服务容器
- 抽象类与接口
- 类多继承的替代方案Traits
- 类的延迟绑定(后期绑定)
- 生成器语法
- 匿名函数和闭包
- 匿名类
- 理解php的output buffer
- 断言ASSERT
- 魔术方法小结
- Zend Opcache字节码缓存
- 内置的http服务器
- SPL标准库
- 【SPL标准库专题(1)】SPL简介
- 【SPL标准库专题(2)】Iterator
- 【SPL标准库专题(3)】Classes
- 【SPL标准库专题(4)】Exceptions
- 【SPL标准库专题(5)】Datastructures:SplDoublyLinkedList
- 【SPL标准库专题(6)】Datastructures:SplStack & SplQueue
- 【SPL标准库专题(7)】Datastructures:SplPriorityQueue
- 【SPL标准库专题(8)】Datastructures:SplHeap & SplMaxHeap & SplMinHeap
- 【SPL标准库专题(9)】Datastructures:SplFixedArray
- 【SPL标准库专题(10)】Datastructures:SplObjectStorage
- PHPcomposer使用手札[ing]
- PHP中的多态
- 通过命名空间实现自动加载的框架雏形
- 日期与金额
- PHPstorm使用攻略
- 笔记本