手把手教你做关键词匹配项目(搜索引擎)---- 第十天

第十天

起点:

1. 手把手教你做关键词匹配项目(搜索引擎)---- 第一天

回顾:

9. 手把手教你做关键词匹配项目(搜索引擎)---- 第九天

小帅帅收到记录Log的任务后,就安心去研究去了。。。

其实按照于老大的水平来说,看惯了开源框架,写个普通的Logger是轻而易举,他为什么要小帅帅去做呢?

小帅帅当时其实也想不通,因为他没有经历过那个阶段。

小帅帅的想法其实也挺简单,就是完成于老大给的任务,成为可以胜任这项工作的好员工。

小帅帅这个阶段对需求不敏感,所以一接到任务他就去研究技术细节去了。 殊不知代码已经写好了。

小帅帅的初稿,就是尝试用面向对象的思维能力去写这个记录Log的任务, 初稿如下:

class Logger {
    
    public static function log($message){
        $file = fopen('application.error.log', "a+");
        fwrite($file, $message);
        fclose($file);
    }
}

那么TopClient的代码如下:

class TopClient {
    ......

    protected function logCommunicationError($apiName, $requestUrl, $errorCode, $responseTxt)
    {
        $localIp = isset($_SERVER["SERVER_ADDR"]) ? $_SERVER["SERVER_ADDR"] : "CLI";

        $logData = "API_NAME:$apiName,APP_KEY:$this->appkey,CLIENT_IP:$localIp,SDK_VERSION:$this->sdkVersion,REQUEST_URL:$requestUrl,ERROR_CODE:$errorCode,ERROR_MSG:".str_replace("\n","",$responseTxt);

        Logger::log($logData);
    }
    ......
}

其实这是一个进步,小帅帅终于在慢慢转变自己的思维能力。

当小帅帅拿着这份代码找到于老大时,于老大很高心,但是不是他想要的成果,于是于老大就对小帅帅说:

1. 如果你要记录错误log,你期望怎么去用,期望看到哪些信息。

2. 如果你要记录警告log, 你期望怎么去用,期望看到哪些信息。

3. 如果你要调试,想看看代码的执行效率,你期望怎么去用,期望看到哪些信息。

三个为什么把小帅帅给压倒了,小帅帅一听,有点气喘不过来。

就这样小帅帅去思索于老大说的话。

小帅帅有幸能听懂其中含义的时候,所学的心法就更加强大,我们期待小帅帅能够开窍。

 

posted @ 2014-08-14 11:40  oShine.Q  阅读(2679)  评论(4编辑  收藏  举报