PHP隊(duì)列用法實(shí)例
本文實(shí)例講述了PHP隊(duì)列用法。分享給大家供大家參考。具體分析如下:
什么是隊(duì)列,是先進(jìn)先出的線性表,在具體應(yīng)用中通常用鏈表或者數(shù)組來實(shí)現(xiàn),隊(duì)列只允許在后端進(jìn)行插入操作,在前端進(jìn)行刪除操作。
什么情況下會(huì)用了隊(duì)列呢,并發(fā)請(qǐng)求又要保證事務(wù)的完整性的時(shí)候就會(huì)用到隊(duì)列,當(dāng)然不排除使用其它更好的方法,知道的不仿說說看。
隊(duì)列還可以用于減輕數(shù)據(jù)庫服務(wù)器壓力,我們可以將不是即時(shí)數(shù)據(jù)放入到隊(duì)列中,在數(shù)據(jù)庫空閑的時(shí)候或者間隔一段時(shí)間后執(zhí)行。比如訪問計(jì)數(shù)器,沒有必要即時(shí)的執(zhí)行訪問增加的Sql,在沒有使用隊(duì)列的時(shí)候sql語句是這樣的,假設(shè)有5個(gè)人訪問:
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請(qǐng)求次數(shù),從而達(dá)到減輕服務(wù)器壓力的效果, 當(dāng)然訪問量不是很大網(wǎng)站根本沒有這個(gè)必要。
下面一個(gè)隊(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;
}
}
/**
* 將一個(gè)單元單元放入隊(duì)列末尾
* @param mixed $value
*/
function enQueue($value)
{
$this->_queue[] = $value;
$this->cache->set($this->queuecachename, $this->_queue);
return $this;
}
/**
* 將隊(duì)列開頭的一個(gè)或多個(gè)單元移出
* @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ì)列中的第一個(gè)單元
*/
function peek()
{
return $this->_queue[0];
}
/**
* 返回隊(duì)列中的一個(gè)或多個(gè)單元
* @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);
}
}
希望本文所述對(duì)大家的PHP程序設(shè)計(jì)有所幫助。
- PHP中使用數(shù)組實(shí)現(xiàn)堆棧數(shù)據(jù)結(jié)構(gòu)的代碼
- PHP使用數(shù)組實(shí)現(xiàn)隊(duì)列
- 關(guān)于PHP堆棧與列隊(duì)的學(xué)習(xí)
- PHP基于堆棧實(shí)現(xiàn)的高級(jí)計(jì)算器功能示例
- PHP棧的定義、入棧出棧方法及基于堆棧實(shí)現(xiàn)的計(jì)算器完整實(shí)例
- php中使用redis隊(duì)列操作實(shí)例代碼
- PHP 數(shù)據(jù)結(jié)構(gòu)隊(duì)列(SplQueue)和優(yōu)先隊(duì)列(SplPriorityQueue)簡單使用實(shí)例
- PHP消息隊(duì)列用法實(shí)例分析
- php實(shí)現(xiàn)的雙向隊(duì)列類實(shí)例
- PHP基于Redis消息隊(duì)列實(shí)現(xiàn)發(fā)布微博的方法
- PHP基于數(shù)組實(shí)現(xiàn)的堆棧和隊(duì)列功能示例
相關(guān)文章
收集的PHP中與數(shù)組相關(guān)的函數(shù)
收集的PHP中與數(shù)組相關(guān)的函數(shù)...2007-03-03
php與python實(shí)現(xiàn)的線程池多線程爬蟲功能示例
這篇文章主要介紹了php與python實(shí)現(xiàn)的線程池多線程爬蟲功能,結(jié)合實(shí)例形式分析了php與python實(shí)現(xiàn)線程池多線程爬蟲的完整實(shí)現(xiàn)方法,需要的朋友可以參考下2016-10-10
修改php.ini實(shí)現(xiàn)Mysql導(dǎo)入數(shù)據(jù)庫文件最大限制的修改方法
這里介紹修改php.ini實(shí)現(xiàn)Mysql導(dǎo)入數(shù)據(jù)庫文件最大限制的修改方法,簡單說明了wampserver服務(wù)器上針對(duì)php.ini配置文件上傳限制參數(shù)、內(nèi)存限制參數(shù)以及post傳輸參數(shù)等修改方法,需要的朋友可以參考一下2007-12-12
php下圖片文字混合水印與縮略圖實(shí)現(xiàn)代碼
php中圖片文字混合水印與縮略圖的實(shí)現(xiàn)代碼,需要的朋友可以參考下。2009-12-12
從PHP $_SERVER相關(guān)參數(shù)判斷是否支持Rewrite模塊
這篇文章主要介紹了如何通過判斷PHP $_SERVER相關(guān)參數(shù)來驗(yàn)證頁面是否重定向,但這只是在Apache環(huán)境下才有效,下面來具體的看下2013-09-09
php array_map與array_walk比較案例詳解
這篇文章主要介紹了php array_map與array_walk比較案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09

