今天小編就為大家帶來一篇PHP中的pthread拓展使用的文章。小編覺得挺不錯的,為此分享給大家做個參考。一起跟隨小編過來看看吧。
PHP是為WEB開發而生,以前PHP是沒有線程的說法,直到pthread的出現,這樣php增加了活力;
一. 線程的創建和使用
1. Thread類
基本的創建和使用:
<?php
//通過繼承Thread類來實現自己的線程類MyThread
class MyThread extends Thread{
//重寫構造函數
function __construct(){
}
//重寫run方法(運行的是子線程需要執行的任務)
function run(){
}
}
//對象的實例化和運行就和java一樣
$mt = new MyThread();
$mt->start();當然,作為線程類,必須還有另外一些用于查詢線程狀態以及管理線程的方法
<?php //獲取創建線程的父線程id Thread::getCreatorId //獲取當前線程id Thread::getCurrentThreadId //獲取當前線程引用 Thread::getCurrentThread //將線程加入檢測 Thread::join //查看線程是否被檢測(是否被join) Thread::isJoined //強行殺死線程 Thread::kill
2.Worker類
Worker類的父類是Thread類,因此基本用法和Thread一樣。而Worker類相對于Thread類來說,增加了線程復用的功能(以降低創建銷毀線程所耗費的資源),通常與Stackable類連用,也就是說worker類既可以當做線程使用,也可以當做任務的容器來使用,如:
<?php
class 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類還有其他一些方法來用于父線程對其進行管理
//獲取還沒執行的任務數量 Worker::getStacked //判斷worker是否關閉 Worker::isShutdown //判斷worker是否在工作 Worker::isWorking //關閉銷毀worker Worker::shutdown //將任務壓棧 Worker::stack //將任務出棧(該api有問題,慎用) Worker::unstack
二. PHP線程遇到的一些問題與注意點
1.線程類的屬性不能直接進行哈希表(數組)操作,如:
//這樣是無效的 $this->var1["hello"] = "world"; //改為 $this->var1 = ["hello"=>"world"];
為什么?因為線程類屬性的賦值是通過序列化實現的,其本質是存儲了序列化數據,因此不支持PHP常用直接操作哈希表(數組)的操作。
2.線程類的屬性不能是“閉包函數”
原因:閉包函數不能序列化;因此,如果想在線程里用“回調函數”的話,那就放棄線程吧;
3.線程對象開辟了php的第二空間
(1)線程在創建之后,無法訪問到父線程的變量,諸如$GLOBALS或global等用法都無法操作父線程的全局變量,這應該是考慮到了線程安全的問題;
(2)但是父線程卻能夠訪問子線程對象的內容;
看完上訴內容,你們對PHP中的pthread拓展使用大概了解了嗎?如果想了解更多相關文章內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。