可以肯定的是,这不是重复的……就这样。
我的目标是在调试类中重载多个魔术方法,并让我的主类扩展所述类。我的想法是,这将允许我通过应用程序堆栈进行调试,而不必一个一个地重载每个类中的魔术方法。
到目前为止,代码看起来像这样
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类中定义的魔法方法。我认为它不像我预期的那样工作。这可能只是我对魔术方法和重载以及继承缺乏了解。有人可以告诉我到底出了什么问题吗?或者甚至是更好的方法来做我想做的事情?