我尝试实现如下代码所示的__isset魔术方法,
为什么我总是得到一个未定义的索引错误?有人能告诉我怎么做吗?
class c {
public $x = array();
public function __get($name) {
return $this->x[$name]; //undefined index: #1:a / #2:b / #3:d
}
public function __isset($name) {
return isset($this->x[$name]);
}
}
$c = new c;
var_dump(isset($c->a));
var_dump(isset($c->a->b)); #1
var_dump(isset($c->b->c)); #2
var_dump(isset($c->d['e'])); #3为什么下面的代码运行良好?我不明白?
$x = array();
var_dump(isset($x->a->b->c));
var_dump(isset($x['a']['b']['c']));发布于 2013-05-03 06:13:48
您可能会认为,PHP引擎将在每次访问PHP中的隐藏属性之前调用__isset()。但那不是真的。检查documentation
通过对不可访问的属性调用isset()或
()来触发__isset()。
因此,这是预期的行为,因为只有:
var_dump(isset($c->a));将触发__isset()。
所有其他行都将触发__get()。由于您没有设置这些索引,因此这是预期行为。
将您的代码更改为:
class c {
public $x = array();
public function __get($name) {
var_dump(__METHOD__);
return $this->x[$name];
}
public function __isset($name) {
var_dump(__METHOD__);
return isset($this->x[$name]);
}
}查看实际调用了哪些方法。这将为您提供:
c::__isset <------ called!
bool(false)
c::__get
Notice: Undefined index: a in /tmp/a.php on line 6
Call Stack:
0.0002 647216 1. {main}() /tmp/a.php:0
0.0003 648472 2. c->__get() /tmp/a.php:16
<---------------------- not called
bool(false)
c::__get
Notice: Undefined index: b in /tmp/a.php on line 6
Call Stack:
0.0002 647216 1. {main}() /tmp/a.php:0
0.0005 648656 2. c->__get() /tmp/a.php:17
<---------------------- not called
bool(false)
c::__get
Notice: Undefined index: d in /tmp/a.php on line 6
Call Stack:
0.0002 647216 1. {main}() /tmp/a.php:0
0.0006 648840 2. c->__get() /tmp/a.php:18
<---------------------- not called
bool(false)发布于 2013-05-03 06:20:22
您有一个实现不佳的__get
$c = new c();
var_dump(isset($c->a)); // false
var_dump(isset($c->a->b)); // false
var_dump(isset($c->b->c)); // false
var_dump(isset($c->d['e'])); // false
class c {
public $x = array();
public function __get($name) {
return isset($name) ? $this->x[$name] : null;
}
public function __isset($name) {
return isset($this->x[$name]);
}
}https://stackoverflow.com/questions/16348497
复制相似问题