由于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();
结果如下: