- 相關(guān)推薦
分析PHP隊(duì)列是什么
PHP具有非常強(qiáng)大的功能,所有的CGI的功能PHP都能實(shí)現(xiàn),而且支持幾乎所有流行的數(shù)據(jù)庫以及操作系統(tǒng)。最重要的是PHP可以用C、C++進(jìn)行程序的擴(kuò)展!今天,小編為大家搜索整理了PHP隊(duì)列是什么,希望大家能有所收獲,更多精彩內(nèi)容請持續(xù)關(guān)注我們考試網(wǎng)!
什么是隊(duì)列,是先進(jìn)先出的線性表,在具體應(yīng)用中通常用鏈表或者數(shù)組來實(shí)現(xiàn),隊(duì)列只允許在后端進(jìn)行插入操作,在前端進(jìn)行刪除操作。
什么情況下會用了隊(duì)列呢,并發(fā)請求又要保證事務(wù)的完整性的時候就會用到隊(duì)列,當(dāng)然不排除使用其它更好的方法,知道的不仿說說看。
隊(duì)列還可以用于減輕數(shù)據(jù)庫服務(wù)器壓力,我們可以將不是即時數(shù)據(jù)放入到隊(duì)列中,在數(shù)據(jù)庫空閑的時候或者間隔一段時間后執(zhí)行。比如訪問計(jì)數(shù)器,沒有必要即時的執(zhí)行訪問增加的Sql,在沒有使用隊(duì)列的時候sql語句是這樣的,假設(shè)有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
而使用隊(duì)列這后就可以這樣:
update table1 set count=count+5 where id=1
減少sql請求次數(shù),從而達(dá)到減輕服務(wù)器壓力的效果, 當(dāng)然訪問量不是很大網(wǎng)站根本沒有這個必要。
下面一個隊(duì)列類:
/**
* 隊(duì)列
*
* @author jaclon
*
*/
class Queue
{
private $_queue = array();
protected $cache = null;
protected $queuecachename;
/**
* 構(gòu)造方法
* @param string $queuename 隊(duì)列名稱
*/
function __construct($queuename)
{
$this->cache =& Cache::instance();
$this->queuecachename = queue_ . $queuename;
$result = $this->cache->get($this->queuecachename);
if (is_array($result)) {
$this->_queue = $result;
}
}
/**
* 將一個單元單元放入隊(duì)列末尾
* @param mixed $value
*/
function enQueue($value)
{
$this->_queue[] = $value;
$this->cache->set($this->queuecachename, $this->_queue);
return $this;
}
/**
* 將隊(duì)列開頭的一個或多個單元移出
* @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;
}
/**
* 將隊(duì)列開頭的單元移出隊(duì)列
*/
function deQueue()
{
$entry = array_shift($this->_queue);
$this->cache->set($this->queuecachename, $this->_queue);
return $entry;
}
/**
* 返回隊(duì)列長度
*/
function size()
{
return count($this->_queue);
}
/**
* 返回隊(duì)列中的第一個單元
*/
function peek()
{
return $this->_queue[0];
}
/**
* 返回隊(duì)列中的一個或多個單元
* @param int $num
*/
function peeks($num)
{
if (count($this->
;_queue) < $num) {
$num = count($this->_queue);
}
return array_slice($this->_queue, 0, $num);
}
/**
* 消毀隊(duì)列
*/
function destroy()
{
$this->cache->remove($this->queuecachename);
}
}
【分析PHP隊(duì)列是什么】相關(guān)文章:
PHP與ASP的分析對比10-27
php中使用redis隊(duì)列操作實(shí)例代碼05-16
php語言是什么05-21
php是什么文件10-09
PHP頁面漏洞分析的方法08-13
php中引用的用法分析06-22
PHP中的trait是什么08-13
php語言的優(yōu)勢是什么09-28
PHP常用開發(fā)工具分析06-27