1. 云栖社区>
  2. PHP教程>
  3. 正文

PHP实现队列及队列原理

作者:用户 来源:互联网 时间:2017-12-01 11:43:05

队列原理

PHP实现队列及队列原理 - 摘要: 本文讲的是PHP实现队列及队列原理, 队列是一种线性表,按照先进先出的原则进行的:看看各语言实现队列的方法:PHP实现队列:第一个元素作为队头,最后一个元素作为队尾<?php/** * 队列就是这么简单 * * @link http://www.phpddt.com

队列是一种线性表,按照先进先出的原则进行的:

<a href=PHP实现队列及队列原理">看看各语言实现队列的方法:

PHP实现队列及队列原理PHP实现队列:第一个元素作为队头,最后一个元素作为队尾
<?php/** * 队列就是这么简单 *  * @link http://www.phpddt.com  */$array =  array('PHP', 'JAVA');array_push($array, 'PYTHON'); //入队列array_shift($array); //出队列


什么是双端队列(或双向队列)Deque,全名double-ended queue。
即元素可以在队列的任意一段入队或出队,如果我们把这些方法叫做insertLeft()和insertRight(),以及removeLeft()和removeRight()。如果严格禁止调用insertLeft()和removeLeft()方法(或禁用右段的操作),双端队列功能就和栈一样。禁止调用insertLeft()和removeRight()(或相反的另一对方法),它的功能就和队列一样了。双端队列与栈或队列相比,是一种多用途的数据结构。
PHP实现双端队列:
<?phpclass Deque  {     public $queue = array(); /**(尾部)入队  **/     public function addLast($value)      { return array_push($this->queue,$value);     }     /**(尾部)出队**/     public function removeLast()      { return array_pop($this->queue);     }     /**(头部)入队**/     public function addFirst($value)      { return array_unshift($this->queue,$value);     }     /**(头部)出队**/     public function removeFirst()      { return array_shift($this->queue);     }     /**清空队列**/     public function makeEmpty()      { unset($this->queue);    } /**获取列头**/    public function getFirst()      { return reset($this->queue);     }     /** 获取列尾 **/    public function getLast()      { return end($this->queue);     }    /** 获取长度 **/    public function getLength()      { return count($this->queue);     }    }


队列的用途:
队列可以很好地异步处理数据传送和存储,当你频繁地向数据库中插入数据、频繁地向搜索引擎提交数据,就可采取队列来异步插入。另外,还可以将较慢的处理逻辑、有并发数量限制的处理逻辑,通过消息队列放在后台处理,例如FLV视频转换、发送手机短信、发送电子邮件等。

以上是云栖社区小编为您精心准备的的内容,在云栖社区的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索队列 原理 ,以便于您获取更多的相关知识。

弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率

40+云计算产品,6个月免费体验

现在注册,免费体验40+云产品,及域名优惠!

云服务器9.9元/月,大学必备