基于PHP pthreads實現(xiàn)多線程代碼實例
在某些情況,我們要使用 PHP 進行重復(fù)的任務(wù),但是只能完成單次,疊加起來的話執(zhí)行時間會非常長,所以就要將任務(wù)分配到多個線程來分別執(zhí)行。
但 PHP 在默認情況下是沒有多線程的,必須要使用 pthreads PHP 擴展,這個擴展能真正的支持和實現(xiàn)多線程。多線程在處理重復(fù)性的循環(huán)任務(wù),能夠大大縮短程序執(zhí)行時間。
要使用這個擴展,就必須使用線程安全的版本。
在編譯 PHP 的時候, ?enable-maintainer-zts 這個選項是必須的,其他的根據(jù)自己的需求來添加
<?phperror_reporting(E_ALL);class vote extends Thread { public $res = ’’; public $url = array(); public $name = ’’; public $runing = false; public $lc = false; public function __construct($name) { $this->res = ’暫無,第一次運行.’; $this->param = 0; $this->lurl = 0; $this->name = $name; $this->runing = true; $this->lc = false; } public function run() { while ($this->runing) { if ($this->param != 0) {$nt = rand(1, 10);echo time().'線程[{$this->name}]收到任務(wù)參數(shù)::{$this->param},需要{$nt}秒處理數(shù)據(jù).n';$this->res = rand(100, 999);//sleep($nt);$this->lurl = $this->param;$this->param = ’’; } else {echo time().'線程[{$this->name}]等待任務(wù)..n'; } sleep(1); } }}//這里創(chuàng)建線程池.$pool[] = new vote(’a’);$pool[] = new vote(’b’);$pool[] = new vote(’c’);$pool[] = new vote(’d’);$pool[] = new vote(’e’);$pool[] = new vote(’f’);$pool[] = new vote(’g’);$pool[] = new vote(’h’);$pool[] = new vote(’i’);$pool[] = new vote(’j’);//啟動所有線程,使其處于工作狀態(tài)foreach ($pool as $w) { $w->start();}//派發(fā)任務(wù)給線程for ($i = 0; $i < 100; $i++) { $worker_content = rand(10, 99); while (true) { foreach ($pool as $worker) { //參數(shù)為空則說明線程空閑 if ($worker->param==’’) {$worker->param = $worker_content;echo '[{$worker->name}]線程空閑,放入?yún)?shù){$worker_content},上次參數(shù)[{$worker->lurl}]結(jié)果[{$worker->res}].n';break 2; } } sleep(1); }}echo '所有線程派發(fā)完畢,等待執(zhí)行完成.n';//等待所有線程運行結(jié)束while (count($pool)) { //遍歷檢查線程組運行結(jié)束 foreach ($pool as $key => $threads) { if ($worker->param==’’) { echo '[{$threads->name}]線程空閑,上次參數(shù)[{$threads->lurl}]結(jié)果[{$threads->res}].n'; echo '[{$threads->name}]線程運行完成,退出.n'; //設(shè)置結(jié)束標(biāo)志 $threads->runing = false; unset($pool[$key]); } } echo '等待中...n'; sleep(1);}echo '所有線程執(zhí)行完畢.n';?>
這段代碼首先是新建了10個線程池,將他們都激活后,按照任務(wù)的數(shù)量來分配到每個線程上。
當(dāng)一個線程完成他的工作后,繼續(xù)拿到下個任務(wù)繼續(xù)執(zhí)行,直到所有任務(wù)都完成為止。
最后判斷是否全部執(zhí)行完了,并停止線程的運行,釋放內(nèi)存。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Python調(diào)用接口合并Excel表代碼實例2. 一文透徹詳解.NET框架類型系統(tǒng)設(shè)計要點3. ASP.NET MVC使用Boostrap實現(xiàn)產(chǎn)品展示、查詢、排序、分頁4. 通過CSS數(shù)學(xué)函數(shù)實現(xiàn)動畫特效5. .net如何優(yōu)雅的使用EFCore實例詳解6. ASP.NET MVC實現(xiàn)橫向展示購物車7. 通過Ajax方式綁定select選項數(shù)據(jù)的實例8. ajax動態(tài)加載json數(shù)據(jù)并詳細解析9. Python快速將ppt制作成配音視頻課件的操作方法10. ASP.Net Core對USB攝像頭進行截圖
