1、子線程沒法訪問父線程的全局變量,但父線程能夠訪問子線程的變量php
<?php class Task extends Thread { public $data; public function run() { global $num; var_dump($num); $this->data = 'abc'; //這是打印null var_dump($GLOBALS); $GLOBALS['test'] = 'def'; } } //主線程中的全局變量,子線程中是沒法訪問的 //php中建立子線程,它會有一個單獨的堆,運行在單獨的地址空間中 //並不能像有些語言中,子線程是能夠訪問的到主線程中的變量的。 $num = 666; $GLOBALS['test'] = 'test'; $t = new Task(); $t->start() && $t->join(); //主線程能夠訪問子線程的變量 var_dump($t->data);
結果以下:mysql
2、子線程沒法修改父線程的變量sql
<?php class Task extends Thread { private $data; public function __construct(&$data) { $this->data = $data; } public function run() { echo "task data : ", $this->data, "\n"; $this->data = 'def'; echo "task data : ", $this->data, "\n"; } } $data = 'abc'; //咱們這裏傳入的是引用 $t = new Task($data); $t->start() && $t->join(); //可是$data變量數據並沒改變 //這說明咱們經過構造函數傳入Task對象中的$data只是一個拷貝 //子線程中並不可以操做主線程中的變量 var_dump($data);
結果以下:數據庫
3、pthreads v3版本能夠設置成員爲匿名函數函數
<?php class Task extends Thread { private $call; public function __construct() { //pthreads v3版本好像能夠設置成員爲匿名函數 //在v2版本中好像是不能夠的 $this->call = function ($param1, $param2) { echo "task call param1 : {$param1} param2 : {$param2}\n"; }; } public function run() { //直接調用成員匿名函數 ($this->call)("hello", "world"); } } $t = new Task(); $t->start() && $t->join();
結果以下:fetch
4、對於數據庫鏈接資源,咱們須要聲明爲靜態成員this
<?php class Task extends Thread { private $db; public function __construct() { //注意這裏會報錯,不能對PDO實例進行序列化或反序列化 $this->db = new PDO('mysql:dbname=test;host=192.168.33.226', 'root', ''); } public function run() { $result = $this->db->query("select id,name from tb_user"); while ($row = $result->fetch(PDO::FETCH_ASSOC)) { echo "{$row['id']}\t{$row['name']}\n"; } } } $t = new Task(); $t->start() && $t->join();
結果以下:線程
代碼修改以下:對象
<?php class Task extends Thread { //咱們須要把數據庫鏈接資源,聲明爲靜態成員,而後調用靜態方法進行建立 private static $db; //咱們直接在__construct()構造函數裏對$db進行實例化,好像會是null,有興趣的能夠試試 public static function getConn() { if (!is_resource(self::$db)) { self::$db = new PDO('mysql:dbname=test;host=192.168.33.226', 'root', ''); } return self::$db; } public function run() { $result = self::getConn()->query("select id,name from tb_user"); while ($row = $result->fetch(PDO::FETCH_ASSOC)) { echo "{$row['id']}\t{$row['name']}\n"; } } } $t = new Task(); $t->start() && $t->join();
結果以下:blog
最後說明,不排除pthreads之後的版本升級上面的有些問題不會出現。
個人php版本是7.2.4,pthreads的版本是3.1.7dev