首頁  >  文章  >  後端開發  >  PHP之pthread拓展使用以及坑

PHP之pthread拓展使用以及坑

藏色散人
藏色散人轉載
2020-01-17 17:40:212516瀏覽

PHP是為WEB開發而生,以前PHP是沒有線程的說法,直到pthread的出現,這樣php增加了活力;

#推薦:《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拓展使用以及坑的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除