php-队列

作者: jaclon 分类: PHP, Uncategorized 发布时间: 2011-07-14 08:54 ė 68条评论

什么是队列,是先进先出的线性表,在具体应用中通常用链表或者数组来实现,队列只允许在后端进行插入操作,在前端进行删除操作。

什么情况下会用了队列呢,并发请求又要保证事务的完整性的时候就会用到队列,当然不排除使用其它更好的方法,知道的不仿说说看。

队列还可以用于减轻数据库服务器压力,我们可以将不是即时数据放入到队列中,在数据库空闲的时候或者间隔一段时间后执行。比如访问计数器,没有必要即时的执行访问增加的Sql,在没有使用队列的时候sql语句是这样的,假设有5个人访问:

update table1 set count=count+1 where id=1
update table1 set count=count+1 where id=1
update table1 set count=count+1 where id=1
update table1 set count=count+1 where id=1
update table1 set count=count+1 where id=1

而使用队列这后就可以这样:

update table1 set count=count+5 where id=1

减少sql请求次数,从而达到减轻服务器压力的效果, 当然访问量不是很大网站根本没有这个必要。

下面一个队列类:

/**
 * 队列
 * 
 * @author jaclon
 *
 */
class Queue 
{
 private $_queue = array();
 protected $cache = null;
 protected $queuecachename;
 
 /**
 * 构造方法
 * @param string $queuename 队列名称
 */
 function __construct($queuename)
 {
 
 $this->cache =& Cache::instance();
 $this->queuecachename = 'queue_' . $queuename;
 
 $result = $this->cache->get($this->queuecachename);
 if (is_array($result)) {
 $this->_queue = $result;
 }
 }
 
 /**
 * 将一个单元单元放入队列末尾
 * @param mixed $value
 */
 function enQueue($value)
 {
 $this->_queue[] = $value;
 $this->cache->set($this->queuecachename, $this->_queue);
 
 return $this;
 }
 
 /**
 * 将队列开头的一个或多个单元移出
 * @param int $num
 */
 function sliceQueue($num = 1)
 {
 if (count($this->_queue) < $num) {
 $num = count($this->_queue);
 }
 $output = array_splice($this->_queue, 0, $num);
 $this->cache->set($this->queuecachename, $this->_queue);

 return $output;
 }
 
 /**
 * 将队列开头的单元移出队列
 */
 function deQueue()
 {
 $entry = array_shift($this->_queue);
 $this->cache->set($this->queuecachename, $this->_queue);
 
 return $entry;
 }
 
 /**
 * 返回队列长度
 */
 function size()
 {
 return count($this->_queue);
 }
 
 /**
 * 返回队列中的第一个单元
 */
 function peek()
 {
 return $this->_queue[0];
 }
 
 /**
 * 返回队列中的一个或多个单元
 * @param int $num
 */
 function peeks($num)
 {
 if (count($this->_queue) < $num) {
 $num = count($this->_queue);
 }
 return array_slice($this->_queue, 0, $num);
 }
 
 
 
 /**
 * 消毁队列
 */
 function destroy()
 {
 $this->cache->remove($this->queuecachename);
 }
}

本文出自 肥蕉博客@IT技术,热门话题,生活随笔,美图欣赏,转载时请注明出处及相应链接。

本文永久链接: http://www.bananawolf.com/html/2011/07/752.html

8条评论

  1. villen 七月 14, 2011 12:09 下午 回复

    看到代码就晕

    1. jaclon 七月 14, 2011 3:05 下午 回复

      看美女不晕吧,呵呵

      1. villen 七月 14, 2011 3:45 下午 回复

        是的

  2. 网络销售技巧 七月 16, 2011 5:31 下午 回复

    看到头都大了~呵呵~~

  3. lexia 3 七月 20, 2011 3:57 下午 回复

    哇靠,博主提供这么牛X的东西,非看不可了。

  4. walo 七月 30, 2011 5:07 下午 回复

    好晕啊

  5. satsun 八月 12, 2011 4:19 下午 回复

    看丁字裤而来 ,进来一看,没了!!!

  6. Royal 八月 21, 2011 5:16 下午 回复

    同楼上.. 🙁

发表评论

电子邮件地址不会被公开。 必填项已用*标注

*

Ɣ回顶部