【问题标题】:PHP magic methods examplePHP魔术方法示例
【发布时间】:2023-03-14 17:12:02
【问题描述】:

我在 Zend PHP 学习指南中有这个问题,但找不到合适的解释...

<?php
    class Magic {
        public $a = "A";
        protected $b = array("a"=>"A", "b"=>"B", "c"=>"C");
        protected $c = array(1,2,3);

        public function __get($v) {
            echo "$v,";
            return $this->b[$v];
        }
        public function __set($var, $val) {
            echo "$var: $val,";
            $this->$var = $val;
        }
    }

    $m = new Magic();
    echo $m->a.",".$m->b.",".$m->c.",";
    $m->c = "CC";
    echo $m->a.",".$m->b.",".$m->c;
?>

根据指南,解决方案应为“b,c,A,B,C,c: CC,b,c,A,B,C”。我不知道为什么-也许你知道?我的意图是第一次调用 $m->a 会导致结果“a”,但这显然是错误的......

【问题讨论】:

  • 您提供的代码将输出“b,c,A,B,Cmc: CC,b,c,A,B,C”(见this proof)。是错字还是指南的确切内容?
  • 你是对的 - 小错字。现在是正确的codepad.org/H91fpj8q

标签: php magic-methods zend-certification


【解决方案1】:

由于__get()调用echo,一些数据在类外的echo被调用之前被输出。

使用echo 遍历第一行,它是这样执行的:

$m->a   "A" is concatenated
","     "," is concatenated
$m->b   "b," is echoed, "B" is concatenated
","     "," is concatenated
$m->c   "c," is echoed, "C" is concatenated
"m"     "," is concatenated

此时,b,c,已经被echoed,现在显示值为A,B,Cm的字符串。

【讨论】:

  • 太棒了!非常感谢。但是,如果那个人在考试中出现...... :) 谢谢你们!
  • @JanPetzold:没问题。祝你好运!
  • @TimCooper, $m-&gt;c = "CC"; 我们这里已经有了同名的 protected 变量。那么,这在可见性的上下文中应该如何表现呢?如果它覆盖了受保护变量c 的值,那么这不是受保护/私有变量的漏洞吗?如果不是这样,则声明:$this-&gt;$var = $val; 似乎创建了已定义为受保护的同名公共变量。那可能吗?另外,在这条语句之后:$m-&gt;c = "CC";,当我们再次访问$m-&gt;c 时,PHP 再次调用__get,就好像c 没有公开可见性一样。这是否意味着$this-&gt;$var = $val;没有成功执行?
猜你喜欢
  • 2015-09-13
  • 1970-01-01
  • 2014-10-28
  • 2010-10-27
  • 1970-01-01
  • 2011-06-10
  • 2010-12-26
  • 1970-01-01
  • 2011-04-07
相关资源
最近更新 更多