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


    第十天

    起点:

    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("
    ","",$responseTxt);
    
            Logger::log($logData);
        }
        ......
    }

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

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

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

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

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

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

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

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

  • 相关阅读:
    外媒评Mate 10 Pro:智慧拍照惊人,续航能力卓越
    pv(PageView)的解释
    pv(PageView)的解释
    pv(PageView)的解释
    pv(PageView)的解释
    对包含HttpContext.Current.Cache的代码进行单元测试
    读取excel模板填充数据 并合并相同文本单元格
    css
    Aragon:以太坊上的去中心化自治组织管理应用
    Futarchy: 对价值投票,对赌信念
  • 原文地址:https://www.cnblogs.com/oshine/p/3912197.html
Copyright © 2020-2023  润新知