这是一种“陷阱”,因为我认为预期的行为将与 OP 中所述的问题一样。
此外,将 ArrayObject 作为 Object 或 Array 访问时,行为并不一致。
例子:
$foo['b']['c'] = 'value'; // no warning
var_dump($foo);
$bar->b->c = 'value'; // triggers warning
var_dump($bar);
我自己的扩展 ArrayObject 的类也遇到了同样的问题。我无法解决这个问题,但设法通过实施一种我用来链接属性创建的新方法来解决它。
class Arraylist extends ArrayObject
{
public function set($key, $value = null)
{
if (!is_null($value)) {
$val = new ArrayList((array) $value);
} else {
$val = new ArrayList();
}
$this->offsetSet($key, $val);
return $this->offsetGet($key);
}
public function offsetSet($index,$val){
echo $index.':'.$val.PHP_EOL;
parent::offsetSet($index, $val);
}
}
使用 OP 示例:
代码:
$s = new ArrayList();
$s->set('a', 'value');
$s->set('b')->set('c', 'another value');
var_dump($s);
输出:
0:value
a:ArrayList
0:value
b:ArrayList
0:another value
c:ArrayList
0:another value
class ArrayList#5 (2) {
public $a =>
class ArrayList#7 (1) {
string(5) "value"
}
public $b =>
class ArrayList#8 (1) {
public $c =>
class ArrayList#9 (1) {
string(13) "another value"
}
}
}