PHP中使用pthread拓展

一. 線程的創建和使用

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拓展的文章就介紹到這瞭,更多相關PHP pthread拓展內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: