手把手教你作關鍵詞匹配項目(搜索引擎)---- 第十八天

第十八天php

客串:屌絲的坑人表單神器html

走過的那些事兒:數據庫那點事兒sql

起點:手把手教你作關鍵詞匹配項目(搜索引擎)---- 第一天數據庫

回顧:手把手教你作關鍵詞匹配項目(搜索引擎)---- 第十七天函數

上回說到小帥帥把代碼交給於老大時,於老大批了小帥帥,小帥帥真的感受受委屈了。post

咱們回到站在技術總監的角度看問題,技術總監真的要作到監管代碼的可讀行嗎?this

我記得不少公司都是提倡利益,利益做爲衡量一個技術總監的價值。搜索引擎

技術總監作錯了嗎?超出他的職責範圍了嗎?spa

其實於老大看到 LinklistCharListHandle類裏面exec方法出現了三層foreach,就把小帥帥給批了。設計

好嚴格的於老大,仍是於老大對小帥帥的指望比較高。

小帥帥沒辦法,他只好把foreach儘可能提取出來,小帥帥的版本:

class LinklistCharListHandle extends CharListHandle {
    public function exec(){
        $sql = "select word from category_linklist where cid='$this->selectorItem->cid'";
        $linklist = DB::makeArray($sql);
        foreach($linklist as $strWords){
            $words = explode(",",$strWords);

            $this->propertiesTransferCharlist($words);

        }
    }

    public function propertiesTransferCharlist($linkWords){
        $properties = $this->selectorItem->getProperties();
        foreach($properties as $property){

            $this->charlist->addCore($property->value);
            if(in_array($property->value,$linkWords)){
                $this->addCores($linkWords);
            }
        }
    }

    public function addCores($words){
        foreach($words as $char){
            $this->charlist->addCore($char);
        }
    }
}

小帥帥提取了兩個方法,使程序更加可以看懂了。

其實小帥帥的的作法就是使用重構-改善既有代碼的設計的技巧之一,Extract Method 提煉函數

 

Extract Method:將這段代碼放進一個獨立函數中,並讓函數名稱解析該函數的用途。

 

小帥帥頗有成就感,繼續把代碼給於老大的時候,於老大提到了兩點。

1. propertiesTransferCharlist爲何要接受個參數。
2. addCores究竟是那個類的職責範圍。


小帥帥第2種他知道怎麼作,他把該方法移到Charlist類裏面,代碼以下:

<?php
class CharList {

    private $core = array();
    private $blacklist = array();

    public function addCore($char){
        if(!in_array($char,$this->core))
            $this->core[] = $char;
    }
    
    public function addCores($words){
        foreach($words as $char){
            $this->addCore($char);
        }
    }

    public function getCore(){
        return $this->core;
    }

    public function addBlacklist($char){
        if(!in_array($char,$this->blacklist))
            $this->blacklist[] = $char;
    }

    public function getBlacklist(){
        return $this->blacklist;
    }
}

其實小帥帥的此次作法仍是使用重構-改善既有代碼的設計的技巧之一,Move Method 搬移函數。

 

Move Method:在該函數最常引用的類中創建一個有着相似行爲的新函數。將舊函數變成一個單純的委託函數,或是將舊函數徹底移除。

 

小帥實在搞不懂第1個怎麼辦,又去請教於老大,於老大直接把代碼給了小帥帥,於老大的代碼爲:

<?php
class LinklistCharListHandle extends CharListHandle {
    
    private static $linklist; 
    
    public function exec(){
       $this->propertiesTransferCharlist();
    }
    
    public static function linklist($cid){
        if(!isset(self::$linklist) || !isset(self::$linklist[$cid]) || self::$linklist[$cid] == null){
            $sql = "select word from category_linklist where cid='$cid'";
            self::$linklist[$cid] = DB::makeArray($sql);
        }
        return self::$linklist[$cid];
    }

    public function propertiesTransferCharlist(){
        $properties = $this->selectorItem->getProperties();
        foreach($properties as $property){
            
            $this->charlist->addCore($property->value);            
            $this->extendCharlist($property->value);           
        }
    }
    
    public function extendCharlist($char){
        $linklist = self::linklist($this->selectorItem->cid);
        foreach($linklist as $strWords){
            $words = explode(",",$strWords);
            if(in_array($char,$words)){
                $this->charlist->addCores($words);
            }
        }
        
    }    
}

小帥帥看了,發表了一次感嘆,原來代碼隨便改變下,區別這麼大,之前爲啥歷來沒有這感受。

 

小帥帥真但願本身可以獨單一面,不用每天去找於老大。

相關文章
相關標籤/搜索