zoukankan      html  css  js  c++  java
  • PHP实现队列及队列原理

    PHP实现队列:第一个元素作为队头,最后一个元素作为队尾

    <?php
    /**
    * 队列就是这么简单
    * 
    * @link
    */
    $array =  array('PHP', 'JAVA');
    array_push($array, 'PYTHON'); //入队列
    array_shift($array); //出队列
    

    什么是双端队列(或双向队列)Deque,全名double-ended queue?

    即元素可以在队列的任意一段入队或出队,如果我们把这些方法叫做insertLeft()和insertRight(),以及removeLeft()和removeRight()。如果严格禁止调用insertLeft()和removeLeft()方法(或禁用右段的操作),双端队列功能就和栈一样。禁止调用insertLeft()和removeRight()(或相反的另一对方法),它的功能就和队列一样了。双端队列与栈或队列相比,是一种多用途的数据结构。

    <?php
    class 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视频转换、发送手机短信、发送电子邮件等。

  • 相关阅读:
    第十五篇 -- 学习第十四天打卡20190702
    第三篇 -- 方向
    第十四篇 -- 学习第十三天打卡20190701
    yum更换阿里源
    Jenkins+sonar7.3集成
    xshell 5 书写汉字乱码
    zabbix 短信报警
    zabbix 微信报警
    zabbix邮件报警
    zabbix主动监测客户端设置
  • 原文地址:https://www.cnblogs.com/haima/p/9789055.html
Copyright © 2011-2022 走看看