第十八天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); } } } }
小帅帅看了,发表了一次感叹,原来代码随便改变下,区别这么大,之前为啥历来没有这感受。
小帅帅真但愿本身可以独单一面,不用每天去找于老大。