在子类中重载魔术方法

时间:2012-04-30 22:15:23

标签: php debugging inheritance overloading magic-methods

相当确定这不是重复......在这里。

我的目标是在调试类中重载多个魔术方法,并让我的主类扩展所述类。我的想法是,这将允许我在应用程序堆栈中进行调试,而不必逐个重载每个类中的魔术方法。

到目前为止代码看起来像这样

class magicdbg
{
//data container object
private $data;

public function __construct()
{
    require_once("data.php");
    $this->data = data::defInstance();
}

public function __call($name,$arguments)
{
    echo "overloading call <br />";
    $this->data->dbgmsg("Calling method: " . __METHOD__ . " -- with arguments: (" .implode(',',$arguments) . ")");
}

public function __get($var)
{

}
}

和一个扩展它的类

require_once("magicdbg.php");
class salesCtrl extends magicdbg
{
private $data;
public function __construct()
{
    require_once('data.php');
    $this->data = data::defInstance();
    $this->testcall();

}

private function testcall()
{
    echo "test";
}
}

最后是包含magicdbg调用方法的类

class data
{
//application settings
CONST DEBUG = true;

//application messages
//debug messages
private $dbgmsgs;
private $errormsgs = array();
//application objects

//singleton object instance
private static $instance;

public function __construct()
{
    //if debug is enabled instantiate the debug message array
    if(self::DEBUG)
        $this->dbgmsgs = array();
}

public static function defInstance()
{
    echo "defining instance";
    if(!self::$instance)
        self::$instance = new data();

    echo "<br />instance defined<br />";
    return self::$instance;
}

public function dbgmsg($msg)
{
    echo "calling dbgmsg <br />";
    if(self::DEBUG)
        $this->dbgmsgs[] = $msg;
}

public function outputDbg()
{
    if(!self::DEBUG)
        return false;
    echo "testing dbg output <br />";
    $return = '<div id="debug"><ul>';
    foreach($this->dbgmsgs as $msg)
        $return .= "<li>" . $msg . "</li>";

    $return .= "</ul></div>";
    return $return;
}
}

代码实例化如此

require_once('sales.ctrl.php');
$ctrl = new salesCtrl();

最后......我的问题似乎是它甚至没有击中magicdbg类中定义的魔术方法。我认为它不像我期望的那样工作。这可能只是我对魔术方法和重载以及继承的理解不足。有人可以填写我究竟出了什么问题吗?或者甚至是一种更好的方式来做我想要的事情?

1 个答案:

答案 0 :(得分:2)

_call仅针对您的类中未定义的方法执行。对于未定义的方法来说,它就像一个捕获。