java php 架构师之路_PHP 队列

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

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

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

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

update table1 setcount=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 setcount=count+5 where id=1

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

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

下面一个队列类:

/**

* 队列

*

* @author jaclon

*

*/

classQueue

{

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

*/

functionenQueue($value)

{

$this->_queue[] =$value;

$this->cache->set($this->queuecachename,$this->_queue);

return$this;

}

/**

* 将队列开头的一个或多个单元移出

* @param int $num

*/

functionsliceQueue($num= 1)

{

if(count($this->_queue)

$num=count($this->_queue);

}

$output=array_splice($this->_queue, 0,$num);

$this->cache->set($this->queuecachename,$this->_queue);

return$output;

}

/**

* 将队列开头的单元移出队列

*/

functiondeQueue()

{

$entry=array_shift($this->_queue);

$this->cache->set($this->queuecachename,$this->_queue);

return$entry;

}

/**

* 返回队列长度

*/

functionsize()

{

returncount($this->_queue);

}

/**

* 返回队列中的第一个单元

*/

functionpeek()

{

return$this->_queue[0];

}

/**

* 返回队列中的一个或多个单元

* @param int $num

*/

functionpeeks($num)

{

if(count($this->_queue)

$num=count($this->_queue);

}

returnarray_slice($this->_queue, 0,$num);

}

/**

* 消毁队列

*/

functiondestroy()

{

$this->cache->remove($this->queuecachename);

}

}

本文由来源 21aspnet,由 system_mush 整理编辑,其版权均为 21aspnet 所有,文章内容系作者个人观点,不代表 Java架构师必看 对观点赞同或支持。如需转载,请注明文章来源。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值