什么是队列,是先进先出的线性表,在具体应用中通常用链表或者数组来实现,队列只允许在后端进行插入操作,在前端进行删除操作。 什么情况下会用了队列呢,并发请求又要保证事务的完整性的时候就会用到队列,当然不排除使用其它更好的方法,知道的不仿说说看
什么是队列,是先进先出的线性表,在具体应用中通常用链表或者数组来实现,队列只允许在后端进行插入操作,在前端进行删除操作。
什么情况下会用了队列呢,并发请求又要保证事务的完整性的时候就会用到队列,当然不排除使用其它更好的方法,知道的不仿说说看。
队列还可以用于减轻数据库服务器压力,我们可以将不是即时数据放入到队列中,在数据库空闲的时候或者间隔一段时间后执行。比如访问计数器,没有必要即时的执行访问增加的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+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
update table1 set count=count+5 where id=1
减少sql请求次数,从而达到减轻服务器压力的效果, 当然访问量不是很大网站根本没有这个必要。
下面一个队列类:
- /**
- * 队列
- *
- * @author jaclon
- *
- */
- 班级 队列
- {
- 私有$_queue = 数组();
- 受保护$cache = null;
- 受保护$queuecachename;
-
- /**
- * 构造方法
- * @param string $queuename 队列名称
-
*/
- 函数 __construct($queuename)
- {
-
- $this->cache =& Cache::instance();
- $this->queuecachename = 'queue_' 。 $队列名称;
-
- $结果 = $这个 ->缓存->get($this->queuecachename);
- if (is_array($结果)) {
- $这个->_queue = $结果;
- }
- }
-
- /**
- * 将一个单元单元放入队列末尾
- * @param mixed $value
- */
- 函数 enQueue( $value)
- {
- $这个->_queue[] = $value;
- $这个->缓存->设置($这个- >queuecachename, $this->_queue);
-
- 返回$这个;
- }
-
- /**
- * 将队列开头的一个或多个单元移出
- * @param int $num
- * /
- 函数 sliceQueue($num = 1 )
- {
- if (计数 ($this->_queue) $num) {
- $num = 计数($this->_queue );
- }
- $output = array_splice ($this->_queue, 0, $num);
- $这个->缓存->设置($这个- >queuecachename, $this->_queue);
-
- 返回$output;
- }
-
- /**
- * 将队列开头的单元移出队列
- * /
- 函数 deQueue()
- {
- $entry = array_shift($这个 ->_队列);
- $这个->缓存->设置($这个- >queuecachename, $this->_queue);
-
- 返回$条目;
- }
-
- /**
- * 返回队列长度
- */
- 函数 size()
- {
- 返回计数($this->_queue);
- }
-
- /**
- * 返回队列中的第一个单元
- * /
- 函数 peek()
- {
- 返回$this->_queue[0];
- }
-
- /**
- * 返回队列中的一个或多个单元
- * @param int $num
- * /
- 函数 偷看($num)
- {
- 如果 (计数($这个->_queue) $num) {
- $num = 计数($this->_queue);
- }
- 返回array_slice($this->_queue, 0, $num);
- }
-
- /**
- * 消毁队列
- * /
- 函数 destroy()
- {
- $this->缓存->删除($this->;队列缓存名称);
- }
- }
http:// /blog.163.com/lgh_2002/blog/static/44017526201172511139202/