zoukankan      html  css  js  c++  java
  • 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. public function addLast($value)
    7. {
    8. return array_push($this->queue,$value);
    9. }
    10. /**(尾部)出队**/
    11. public function removeLast()
    12. {
    13. return array_pop($this->queue);
    14. }
    15. /**(头部)入队**/
    16. public function addFirst($value)
    17. {
    18. return array_unshift($this->queue,$value);
    19. }
    20. /**(头部)出队**/
    21. public function removeFirst()
    22. {
    23. return array_shift($this->queue);
    24. }
    25. /**清空队列**/
    26. public function makeEmpty()
    27. {
    28. unset($this->queue);
    29. }
    30. /**获取列头**/
    31. public function getFirst()
    32. {
    33. return reset($this->queue);
    34. }
    35.  
    36. /** 获取列尾 **/
    37. public function getLast()
    38. {
    39. return end($this->queue);
    40. }
    41.  
    42. /** 获取长度 **/
    43. public function getLength()
    44. {
    45. return count($this->queue);
    46. }
    47. }


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

  • 相关阅读:
    iOS
    iOS
    iOS
    iOS
    iOS
    iOS
    iOS
    iOS
    iOS
    iOS
  • 原文地址:https://www.cnblogs.com/yubolin/p/6025358.html
Copyright © 2011-2022 走看看