(实用篇)PHP实现队列及队列原理

队列说明

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

640-webp

实现队列

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实现双端队列

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

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/1434.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚的头像重蔚管理团队
上一篇 2016年10月26日
下一篇 2016年10月26日

相关推荐

  • 小编分享php date_diff。

    date_diff()函数用于计算两个日期之间的差值。它接受两个参数,分别是开始日期和结束日期,并返回一个表示这两个日期之间差值的对象。 在PHP中,date_diff()函数是一个内置函数,用于计算两个日期之间的时间差,这…

    2024年7月5日
    00
  • PHP中使用Redis的hyperLogLog计数器

    PHP是一种常用的服务器端编程语言,常常被用于开发Web应用程序。而Redis是一个开源的内存数据库,被广泛使用于缓存、分布式锁等场景。Redis有一个特殊的数据结构——HyperLogLog,可以进行基数估计。在某些场景下,我…

    2023年5月19日
    06
  • php会话技术的基本介绍

    所谓的会话,指的是客户端 和 服务器进行交互的行为 由于客户端 请求 服务器的时候,采用的是http协议,http协议是无状态的协议 我们每次请求服务器,服务器回应之后,该次请求就会消失 举个例子: 张三是服务器,…

    2018年9月13日 PHP自学教程
    0256
  • 关于PHP发数组运算符

    说明:就是对数组进行操作的方式 其实就三种:联合(+)、等于(==,===)、不等于(!=,!==)

    2017年12月12日
    0256
  • 如何用PHP实现微信公众号数据统计

    随着微信公众号逐渐成为企业营销的重要工具之一,对公众号数据的统计分析也变得越来越重要。通过数据分析,可以了解公众号的粉丝数量、活跃度、用户转化率等指标,从而优化运营策略和提高营销效果。本文将介绍如何…

    2023年5月18日
    00
  • PHP中如何进行高性能计算和网络编程。

    随着互联网的蓬勃发展,PHP成为了其中一个常用的编程语言。作为一种面向脚本的语言,PHP对于快速构建Web应用非常方便。然而,PHP在处理大量数据和高并发时,性能问题也相当显著。那么,如何在PHP中进行高性能计算和…

    2023年5月23日
    01
  • 我来教你php多虚拟主机配置的步骤是什么。

    在PHP开发中,多虚拟主机配置是一个常见的需求,通过配置多个虚拟主机,可以在同一台服务器上托管多个网站,每个网站都有自己的域名、目录和配置文件,下面将详细介绍PHP多虚拟主机配置的步骤。 1. 安装Apache和PHP…

    2024年7月12日
    00
  • 如何在PHP中使用Memcached缓存技术提高图片的加载速度

    随着互联网的发展,网站的访问量越来越大,为了提高网站的性能和用户体验,缓存技术成为了必不可少的一部分。其中,Memcached是一种高性能的分布式缓存系统,广泛应用于互联网领域,特别适用于缓存大量的读操作。本…

    2023年5月19日
    01

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息