PHP实现消息队列

                                      PHP实现消息队列

队列是一种线性表,按照先进先出的原则进行的:
看看各语言实现队列的方法
PHP实现队列:第一个元素作为队头,最后一个元素作为队尾

  1. <?php
  2. /**
  3. * 队列就是这么简单
  4. *
  5. * @link http://www.phpddt.com
  6. */
  7. $array = array('PHP', 'JAVA');
  8.  
  9. array_push($array, 'PYTHON'); //入队列
  10.  
  11. array_shift($array); //出队列


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

 

  1. <?php
  2. class Deque
  3. {
  4. public $queue = array();
  5.  
  6. /**(尾部)入队 **/
  7. public function addLast($value)
  8. {
  9. return array_push($this->queue,$value);
  10. }
  11. /**(尾部)出队**/
  12. public function removeLast()
  13. {
  14. return array_pop($this->queue);
  15. }
  16. /**(头部)入队**/
  17. public function addFirst($value)
  18. {
  19. return array_unshift($this->queue,$value);
  20. }
  21. /**(头部)出队**/
  22. public function removeFirst()
  23. {
  24. return array_shift($this->queue);
  25. }
  26. /**清空队列**/
  27. public function makeEmpty()
  28. {
  29. unset($this->queue);
  30. }
  31.  
  32. /**获取列头**/
  33. public function getFirst()
  34. {
  35. return reset($this->queue);
  36. }
  37.  
  38. /** 获取列尾 **/
  39. public function getLast()
  40. {
  41. return end($this->queue);
  42. }
  43.  
  44. /** 获取长度 **/
  45. public function getLength()
  46. {
  47. return count($this->queue);
  48. }
  49.  
  50. }


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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值