PHP中使用pthread拓展
基本的創(chuàng)建和使用:
<?php//通過繼承Thread類來實現(xiàn)自己的線程類MyThreadclass MyThread extends Thread{ //重寫構(gòu)造函數(shù) function __construct(){ } //重寫run方法(運行的是子線程需要執(zhí)行的任務) function run(){ }}//對象的實例化和運行就和java一樣$mt = new MyThread();$mt->start();
當然,作為線程類,必須還有另外一些用于查詢線程狀態(tài)以及管理線程的方法
<?php//獲取創(chuàng)建線程的父線程idThread::getCreatorId //獲取當前線程idThread::getCurrentThreadId//獲取當前線程引用Thread::getCurrentThread //將線程加入檢測Thread::join//查看線程是否被檢測(是否被join)Thread::isJoined//強行殺死線程Thread::kill2.Worker類
Worker類的父類是Thread類,因此基本用法和Thread一樣。而Worker類相對于Thread類來說,增加了線程復用的功能(以降低創(chuàng)建銷毀線程所耗費的資源),通常與Stackable類連用,也就是說worker類既可以當做線程使用,也可以當做任務的容器來使用,如:
<?phpclass Task extends Stackable{ function __construct($no){$this->no = $no; } function run(){echo 'task{$this->no}:run'.PHP_EOL; }}class MyWork extends Worker{ function __construct(){ } function run(){ }}$t1= new Task(1);$t2= new Task(2);$t3= new Task(3);$my = new MyWork();$my->stack($t1);$my->stack($t2);$my->start();$my->stack($t3);
最終輸出:
task1:run task2:run task3:run
當然Worker類還有其他一些方法來用于父線程對其進行管理
//獲取還沒執(zhí)行的任務數(shù)量Worker::getStacked //判斷worker是否關(guān)閉Worker::isShutdown//判斷worker是否在工作Worker::isWorking//關(guān)閉銷毀workerWorker::shutdown//將任務壓棧Worker::stack//將任務出棧(該api有問題,慎用)Worker::unstack二. PHP線程遇到的一些問題與注意點1.線程類的屬性不能直接進行哈希表(數(shù)組)操作,如:
//這樣是無效的$this->var1['hello'] = 'world'; //改為$this->var1 = ['hello'=>'world'];
為什么?因為線程類屬性的賦值是通過序列化實現(xiàn)的,其本質(zhì)是存儲了序列化數(shù)據(jù),因此不支持PHP常用直接操作哈希表(數(shù)組)的操作。
2.線程類的屬性不能是“閉包函數(shù)”原因:閉包函數(shù)不能序列化;因此,如果想在線程里用“回調(diào)函數(shù)”的話,那就放棄線程吧;
3.線程對象開辟了php的第二空間(1)線程在創(chuàng)建之后,無法訪問到父線程的變量,諸如$GLOBALS或global等用法都無法操作父線程的全局變量,這應該是考慮到了線程安全的問題; (2)但是父線程卻能夠訪問子線程對象的內(nèi)容;
到此這篇關(guān)于PHP中使用pthread拓展的文章就介紹到這了,更多相關(guān)PHP pthread拓展內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
