php 频繁插库处理队列,PHP实现队列及队列原理

本文介绍了PHP中如何使用数组实现队列,包括入队、出队操作,并探讨了双端队列(Deque)的概念,它可以允许在两端进行插入和删除操作。双端队列在禁止某些操作时可以模拟栈或队列的行为。队列在处理大量数据插入、异步任务、数据库操作和搜索引擎提交等方面有广泛应用。此外,还提供了一个简单的PHP双端队列类实现。
摘要由CSDN通过智能技术生成

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()(或相反的另一对方法),它的功能就和队列一样了。双端队列与栈或队列相比,是一种多用途的数据结构。

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.cnblogs.com/haima/p/9789055.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值