各位大神好,我實現了一個日志工具基類,并派生了兩個子類,一個是運維日志類,一個是業務日志類,并在基類中設置了一個靜態變量希望能用以區分兩個子類,但在調用靜態方法時,實際上完全不是想象中的情況,代碼如下:
// 日志工具基類
class LogTool
{
protected static $type;
public static function debug($msg) {
switch (self::$type) {
case 'biz':
echo '把日志寫入數據庫表1';
break;
case 'opt':
echo '把日志寫入數據庫表2';
break;
default:
echo 'error';
}
}
// 其他代碼省略
}
// 運維日志類
class OptTool extends LogTool
{
protected static $type = 'opt';
}
// 業務日志類
class BizTool extends LogTool
{
protected static $type = 'biz';
}
// 調用代碼
BizTool::debug('王小虎已登錄');
代碼如上,實際上函數 dosomething 的運行情況是每次都輸出 'error',因為在執行靜態方法debug時,靜態成員 $type 是空值;但是如果我把 debug 函數在子類中再實現一次,則運行時 $type 變量就是有值的。可是這樣做就完全沒意義了,抽象父類出來就是為了減少重復代碼的,現在兩個子類除了寫入日志的表不同,其他完全相同,結果這樣的結果弄得我欲哭無淚。
懇請大神們指點一二,萬分感謝!
- 0 回答
- 0 關注
- 619 瀏覽
添加回答
舉報
0/150
提交
取消