本文實例講述了PHP pthreads v3下的Volatile簡介與使用方法。分享給大家供大家參考,具體如下:
由于pthreads v3中引入了Threaded對象自動不變性的概念,所以當我們在構造函數中給成員設置為數組時,在其他地方就無法對成員再次改寫了。
例子如下:
?php
//pthreads v3引入了Threaded對象自動不變性的概念
//如果成員被設置成Threaded對象,那么它將不能被再次改寫
//當然,這主要還是為了性能優化,但有時我們又需要改寫成員,那么就需要繼承自Volatile類了
class Task extends Thread
{
private $data;
private $result;
public function __construct()
{
$this->data = 'abc';
var_dump($this->data);
//成員設置成標量,是可以再次被改寫的
$this->data = 'def';
var_dump($this->data);
//這里給data設置為數組時,會自動轉換成Volatile對象
$this->data = [1, 2, 3];
var_dump($this->data);
//這個時候再給data賦值時,就會報錯了
//成員被設置成Threaded對象時(Volatile繼承自Threaded),該成員就不能再次被改寫了
$this->data = [4, 5, 6];
var_dump($this->data);
//當然,我們可以顯式的強制轉換,不讓Threaded幫我自動轉成Volatile對象
$this->result = (array)[1, 2, 3];
//打印出來是數組
var_dump($this->result);
$this->result = (array)[4, 5, 6];
//成員賦值成功
var_dump($this->result);
}
}
new Task();
如果我們對成員再次進行改寫,那么就會報錯了。

如果確實需要對成員數據進行改寫,除了上面的顯式強制轉換外,另一個方法就是繼承Volatile類了。
例子如下:
?php
//Volatile類允許其成員可更改
class Task extends Volatile
{
private $data;
public function __construct()
{
//繼承自Volatile類后,我們的成員在設置成Threaded對象后,仍可改寫
$this->data = [
'a' => 123,
'b' => 456,
'c' => 789,
];
var_dump($this->data);
//這里成員數據成功被改寫
$this->data = [
'a' => 'aaa',
'b' => 'bbb',
'c' => 'ccc',
];
var_dump($this->data);
//由于Threaded對象實現了ArrayAccess接口,我們可以像訪問數組一樣,訪問Volatile對象
echo $this->data['a'], "\t", $this->data['b'], "\t", $this->data['c'], "\n";
foreach ($this->data as $item) {
echo $item, "\n";
}
}
}
new Task();
結果如下:

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP進程與線程操作技巧總結》、《PHP網絡編程技巧總結》、《PHP基本語法入門教程》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- PHP pthreads v3在centos7平臺下的安裝與配置操作方法
- PHP pthreads v3下worker和pool的使用方法示例
- PHP pthreads v3下同步處理synchronized用法示例
- PHP pthreads v3使用中的一些坑和注意點分析
- php使用pthreads v3多線程實現抓取新浪新聞信息操作示例
- php pthreads多線程的安裝與使用
- 使用pthreads實現真正的PHP多線程(需PHP5.3以上版本)
- 基于PHP pthreads實現多線程代碼實例