队列

Testing Is Documentation

tests/Stack/QueueTest.php队列 - 图1

队列 (Queue) 具有先进先出的特性,支持在队列尾部插入元素,在队列头部删除元素的特性。

在 PHP 双向链表的基础上加上数据类型验证功能,不少业务场景中保证链表中数据一致性。

阻止链表返回空数据时抛出异常的默认行为。

底层基于 spldoublylinkedlist 开发,相关文档 http://php.net/manual/zh/class.spldoublylinkedlist.php队列 - 图2

标准库文档见 http://php.net/manual/zh/class.splqueue.php队列 - 图3

Uses

  1. <?php
  2. use Leevel\Stack\Queue;

队列基本使用方法

队列是一种操作受限的线性表数据结构,包含两个操作。入队 enqueue,放一个数据到队列尾部; 出队 dequeue,从队列头部取一个元素。

  1. public function testBaseUse(): void
  2. {
  3. $queue = new Queue();
  4. $this->assertSame(0, $queue->count());
  5. // 入对 5
  6. $queue->enqueue(5);
  7. $this->assertSame(1, $queue->count());
  8. // 入对 6
  9. $queue->enqueue(6);
  10. $this->assertSame(2, $queue->count());
  11. // 出对,先进先出
  12. $this->assertSame(5, $queue->dequeue());
  13. $this->assertSame(1, $queue->count());
  14. // 出对,先进先出
  15. $this->assertSame(6, $queue->dequeue());
  16. $this->assertSame(0, $queue->count());
  17. }

队列支持元素类型限定

  1. public function testValidateType(): void
  2. {
  3. $this->expectException(\InvalidArgumentException::class);
  4. $this->expectExceptionMessage('The queue element type verification failed, and the allowed type is string.');
  5. $queue = new Queue(['string']);
  6. $queue->enqueue(5);
  7. }