国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

如何成為一名優秀的工程師(語義篇)

開發 后端
好的語義表達是團隊協作中高效迭代的潤滑劑,好的語義表達是線上未知代碼問題排查的指南針。

好的語義表達是團隊協作中高效迭代的潤滑劑,好的語義表達是線上未知代碼問題排查的指南針。

本篇文章巨長,如果你比較“懶”,來我講給你聽(直播中有更多細節) 回放地址

看完這個還不過癮?學習使你快樂?還想學習?快上車

不要讓其他人讀不懂你的代碼,其他人可能就是一周后的你。時刻以“如果你寫的這段代碼出現故障,一個陌生人接手你的代碼需要多久能處理完這個bug”來監督自己。

日常中應該多多刻意提升自己語義表達,百利而無一害。那么我們應該從哪些細節去做好語義表達呢?  

如何成為一名優秀的工程師(語義篇) 

以下代碼全為我的藝術創作,不屬于任何實際項目

命名

案例1 

  1. function getGoods($query, $shopId) 
  2.     $goodsId = Goods::add($query["uid"], $query["name"]); 
  3.     return Shop::add($goodsId, $shopId); 
  4.  
  5. class Goods 
  6.     public static function add($uid, $name
  7.     { 
  8.         $id = mt_rand(1, 100000); 
  9.         return $id; 
  10.     } 
  11.  
  12. class Shop 
  13.     public static function add($goodsId, $shopId) 
  14.     { 
  15.         $id = mt_rand(1, 100000); 
  16.         return $id; 
  17.     } 
  18. }  

如何成為一名優秀的工程師(語義篇) 

案例2 

  1. function getUserInfo($teamId, $youId = []) 
  2. {  
  3. }  

如果僅僅有這個函數名和參數名,誰能猜到參數的意義呢? 

如何成為一名優秀的工程師(語義篇) 

案例3

  1. class Db 
  2.     /** 
  3.      * @param string $table 數據庫表名 
  4.      * @param array  $data  新增數據 
  5.      * 
  6.      * @return int 新增主鍵 
  7.      */ 
  8.     public static function insert(string $table, array $data) 
  9.     { 
  10.         $id = mt_rand(1, 1000); 
  11.         return $id; 
  12.     } 
  13.  
  14. class ViewLogStore 
  15.     private $table = "view_log"
  16.  
  17.     function setHistory($data) 
  18.     { 
  19.         Db::insert($this->table, $data); 
  20.     } 
  21. }  

 

案例4

假如業務代碼里有這些類 

  1. class WechatUserModel{ 
  2. class WechatGroupModel{ 
  3. class WechatMessageModel{ 
  4. }  

而我們查詢數據庫發現 

 

這樣我們根據業務代碼就非常不方便找到對應的表,而且其他人接手我們項目的時候,也會摸不著頭腦。或者說這可能是三個人三次迭代開發造成的,那么他們彼此都沒有去參考前面人的命名規則。

來自靈魂的拷問

 

注釋

說完命名,下面說下注釋。注釋里還有什么學問?Are you kidding me?

一個數組對象成員,你知道怎么寫嗎?

類的魔術方法調用的注釋,你知道怎么寫嗎?

對象數組 

  1. /** 
  2.  * @var Ads[] 
  3.  */ 
  4. public $adsList = [];  

 

  1. $blocks = [];/** @var $blocks Block[] **/  

如何成為一名優秀的工程師(語義篇)

@method 的使用 

  1. /** 
  2.  * @link http://manual.phpdoc.org/HTMLframesConverter/default
  3.  * 
  4.  * @method static int search(string $query, $limit = 10, $offset = 0) 
  5.  */ 
  6. class SearchServiceProxy 
  7.     public static function __callStatic($method, $arguments) 
  8.     { 
  9.         if (!method_exists("SearchService", $method)) { 
  10.             throw new \LogicException(__CLASS__ . "::" . $method . " not found"); 
  11.         } 
  12.  
  13.         try { 
  14.             $data = call_user_func_array(["SearchService", $method], $arguments); 
  15.         } catch (\Exception $e) { 
  16.             error_log($e->getMessage()); 
  17.             return false
  18.         } 
  19.  
  20.         return $data; 
  21.     } 
  22. }  

 

 

 

@deprecated 使用  

  1. class SearchService 
  2.  
  3.     /** 
  4.      * @param string $query 
  5.      * @param int    $limit 
  6.      * @param int    $offset 
  7.      * 
  8.      * @return array 
  9.      * @deprecated 
  10.      */ 
  11.     public static function search(string $query, $limit = 10, $offset = 0) 
  12.     { 
  13.         return [ 
  14.             ["id" => 1, "aaa"], 
  15.             ["id" => 2, "bbb"], 
  16.         ]; 
  17.     } 
  18.  

 

 

 

注釋其他注意事項

注釋解釋張冠李戴,方法名更新,方法的功能業務注釋沒更新;復制別人的代碼把 @author 信息也復制過來了,錯誤了還要把鍋甩給別人。

注釋更多參考 http://manual.phpdoc.org/HTML...

函數、方法

案例1

先說明一句,不好的代碼不妨礙它成為一個優秀的軟件。PHP MySQL 爛代碼多的去了。

找到一個開源軟件里面的代碼,功能非常搶到,但是這個方法內容太多,一些不足點我標注出來了。 

 

 

 

案例2

拿上面我舉例子,還記得下面這種圖嗎? 

 

優化方案1 

  1. class ArrayUtils{ 
  2.     public static function fetch($arr, $keys, $setNull = false
  3.     { 
  4.         $ret = array(); 
  5.         foreach($keys as $key
  6.         { 
  7.             if ($setNull) 
  8.             { 
  9.                 $ret[$key] = $arr[$key]; 
  10.             } 
  11.             else 
  12.             { 
  13.                 isset($arr[$key]) && $ret[$key] = $arr[$key]; 
  14.             } 
  15.         } 
  16.         return $ret; 
  17.     } 
  18.  
  19.  
  20. class ViewLogStore 
  21.     private $table = "view_log"
  22.  
  23.     function record($data) 
  24.     { 
  25.         $fields = array( 
  26.             'uid'
  27.             'url'
  28.             'referer'
  29.             'created_time' 
  30.         ); 
  31.         $data = ArrayUtils::fetch($data, $fields); 
  32.         Db::insert($this->table, $data); 
  33.     } 
  34.  

優化方案2 

  1. class Db 
  2.     /** 
  3.      * @param string $table 數據庫表名 
  4.      * @param Entity $data  新增對象 
  5.      * 
  6.      * @return int 新增主鍵 
  7.      */ 
  8.     public static function insert(string $table, Entity $data) 
  9.     { 
  10.         $array = $data->toArray(); 
  11.         var_export($array); // test 
  12.  
  13.         $id = mt_rand(1, 1000); 
  14.         return $id; 
  15.     } 
  16.  
  17. class ArrayUtils 
  18.     /** 
  19.      * 針對成員都是私有屬性的對象 
  20.      * 
  21.      * @param      $obj 
  22.      * @param bool $removeNull 去掉空值 
  23.      * @param bool $camelCase 
  24.      * 
  25.      * @return array 
  26.      */ 
  27.     public static function Obj2Array($obj, $removeNull = true, $camelCase = true
  28.     { 
  29.         $reflect = new \ReflectionClass($obj); 
  30.         $props = $reflect->getProperties(\ReflectionProperty::IS_PUBLIC | \ReflectionProperty::IS_PRIVATE | \ReflectionProperty::IS_PROTECTED); 
  31.  
  32.         $array = []; 
  33.         foreach ($props as $prop) { 
  34.             $prop->setAccessible(true); 
  35.             $key = $prop->getName(); 
  36.  
  37.             // 如果不是駝峰命名方式,就把對象里面的 createTime 轉成 create_time 
  38.             if (!$camelCase) { 
  39.                 $key = preg_replace_callback("/[A-Z]/"function ($matches) { 
  40.                     return "_" . strtolower($matches[0]); 
  41.                 }, $key); 
  42.                 $key = ltrim($key"_"); 
  43.             } 
  44.  
  45.             $value = $prop->getValue($obj); 
  46.  
  47.             if ($removeNull == true && $value === null) { 
  48.                 continue
  49.             } 
  50.  
  51.             if (is_object($value)) { 
  52.                 $value = self::Obj2Array($value); 
  53.             } 
  54.  
  55.             $array[$key] = $value; 
  56.         } 
  57.  
  58.         return $array; 
  59.     } 
  60.  
  61. class Entity 
  62.     public function toArray(){ 
  63.         return ArrayUtils::Obj2Array($this); 
  64.     } 
  65.  
  66. class ViewLogEntity extends Entity 
  67.     /** 
  68.      * @var int 
  69.      */ 
  70.     private $uid; 
  71.  
  72.     /** 
  73.      * @var string 
  74.      */ 
  75.     private $url; 
  76.  
  77.     /** 
  78.      * @var string 
  79.      */ 
  80.     private $referer; 
  81.  
  82.     /** 
  83.      * @var string 
  84.      */ 
  85.     private $createdTime; 
  86.  
  87.     /** 
  88.      * @param int $uid 
  89.      */ 
  90.     public function setUid(int $uid) 
  91.     { 
  92.         $this->uid = $uid; 
  93.     } 
  94.  
  95.     /** 
  96.      * @param string $url 
  97.      */ 
  98.     public function setUrl(string $url) 
  99.     { 
  100.         $this->url = $url; 
  101.     } 
  102.  
  103.     /** 
  104.      * @param string $referer 
  105.      */ 
  106.     public function setReferer(string $referer) 
  107.     { 
  108.         $this->referer = $referer; 
  109.     } 
  110.  
  111.     /** 
  112.      * @param string $createdTime 
  113.      */ 
  114.     public function setCreatedTime(string $createdTime) 
  115.     { 
  116.         $this->createdTime = $createdTime; 
  117.     } 
  118.  
  119.  
  120. class ViewLogStore 
  121.     private $table = "view_log"
  122.  
  123.     function record(ViewLogEntity $viewLogEntity) 
  124.     { 
  125.         Db::insert($this->table, $viewLogEntity); 
  126.     } 
  127.  
  128. // 測試 
  129.  
  130. $viewLogEntity = new ViewLogEntity(); 
  131. $viewLogEntity->setUid(1); 
  132. $viewLogEntity->setReferer("https://mengkang.net"); 
  133. $viewLogEntity->setUrl("https://segmentfault.com/l/1500000018225727"); 
  134. $viewLogEntity->setCreatedTime(date("Y-m-d H:i:s",time())); 
  135.  
  136. $viewLogStore = new ViewLogStore(); 
  137. $viewLogStore->record($viewLogEntity);  

案例3

這還是函數嗎?(不僅僅是語義,屬于錯誤) 

  1. /** 
  2.  * @method mixed fetchList(string $sql, array $argv); 
  3.  */ 
  4. class Model 
  5.  
  6.     public function __construct($table
  7.     { 
  8.  
  9.     } 
  10.  
  11. function getUserList($startId, $lastId, $limit = 100) 
  12.     if ($lastId > 0) { 
  13.         $startId = $lastId; 
  14.     } 
  15.  
  16.     $sql = "select * from `user` where id > ? order by id asc limit ?,?"
  17.  
  18.     $model = new Model('user'); 
  19.     return $model->fetchList($sql, [intval($startId), intval($limit)]); 
  20.  

$startId和$lastId兩個參數重復

案例4

盡量減少參數引用 

  1. function bad($input1, $input2, &$input3) 
  2.     //...logic 
  3.  
  4.     $input3 = "xxx"
  5.  
  6.     return true
  7.  

案例5

參數類型明確,返回值類型明確,不要出現 mixed。這個我直接拿官方的函數來舉例,對權威也要有懷疑的眼光。純屬個人看法。 

 

 

 

案例6 

 

 

 

上面例子中你會發現這個addUser寫得不想一個函數(方法)而像一個遠程api接口。而且在右邊的代碼中需要每次使用的時候都要用is_array來判斷。這是非常不友好的語義表達。PHP Java 這樣的高級語言有異常,我們要善用異常。 

 

 

 

好的語義表達是團隊協作中高效迭代的潤滑劑,好的語義表達是線上未知代碼問題排查的指南針。這篇博客到這里就結束了,不知道你是否有一些收獲呢? 

 

 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2012-11-29 10:05:20

2016-02-25 11:42:19

2017-04-14 10:37:21

2021-07-29 11:14:03

DevOpsLinux工程師

2009-02-10 15:39:59

軟件評測師軟考經驗

2016-10-21 15:57:10

2011-05-03 08:54:36

2017-09-21 09:44:00

編程程序員軟件開發

2016-06-27 10:40:12

軟件測試敏捷開發

2014-12-23 09:40:41

CTO

2020-06-29 14:54:19

網絡技術專家講座

2013-09-25 10:47:25

創新公司員工

2014-05-22 10:43:26

移動開發者優秀

2021-01-18 09:00:00

人工智能機器學習工程師

2016-01-28 11:18:09

卓越前端工程師

2014-01-13 11:04:32

2013-01-07 09:41:48

2021-05-25 09:51:42

架構運維技術

2018-03-29 11:23:25

IT人員云計算工程師

2009-04-02 18:29:05

點贊
收藏

51CTO技術棧公眾號

91免费国产网站| 91精品国产网站| 国产91色在线播放| 黄瓜视频免费观看在线观看www| 黄网视频在线观看| 国产精品刘玥久久一区| 婷婷精品视频| 91亚洲精品一区二区乱码| 久久精品人人做人人爽电影蜜月| 性一交一乱一区二区洋洋av| 大地资源网3页在线观看| 日本视频不卡| 在线日韩影院| 亚洲91网站| 国产在线欧美| 欲色天天网综合久久| 麻豆精品视频在线| 超碰地址久久| 日本视频在线免费观看| 日韩精品―中文字幕| 91丝袜美腿美女视频网站| 亚洲天堂成人在线| 五月天丁香久久| 麻豆精品视频在线观看| 同性恋视频一区| 51漫画成人app入口| 成人亚洲成人影院| 午夜精品电影在线观看| 日本电影亚洲天堂| 亚洲国产精品专区久久| 亚洲精品大片www| 韩国成人在线视频| 婷婷久久国产对白刺激五月99| 日韩精品影片| 韩国免费在线视频| 99免费视频观看| 老司机精品福利在线观看| 91精品国产乱码久久久久久久久| 精品国产乱码久久久久久老虎| 亚洲靠逼com| 成人午夜视频网站| 亚洲成人中文| 免费欧美一区| 亚洲成人短视频| 成人免费在线视频网| 99热在线看| 亚洲一区二区三区av无码| 久久国产精品 国产精品| 清纯唯美日韩制服另类| 中文在线不卡视频| 91精品国产综合久久久久久久| 亚洲黄色av一区| 成人免费高清视频在线观看| 国产精品一区毛片| 四虎成人av| 动漫av一区| www.成人在线视频| heyzo中文字幕在线| 久久久久国产精品嫩草影院| av美女在线| 国产1区2区在线| 欧美日韩在线免费观看视频| 中文字幕人成一区| 极品国产人妖chinesets亚洲人妖| 午夜精品一区| 色视频网站在线| 日韩伦理在线免费观看| 欧美日本亚洲| 国产日韩欧美在线看| 视频直播国产精品| 制服丝袜激情欧洲亚洲| 亚洲一区二区av电影| 久久久精品国产免费观看同学| 麻豆91在线观看| 日韩视频一区| 一级欧洲+日本+国产| 一区三区在线欧| 国产一精品一av一免费爽爽| 樱花草涩涩www在线播放| 麻豆传媒在线免费| 校园春色欧美| 性一爱一乱一交一视频| 最新中文字幕免费视频| 日韩日韩日韩日韩日韩| 一区二区三区四区五区精品| 国产欧美在线一区二区| 国产精品视频地址| 91精品国产高清| 欧美国产乱视频| 久久精品电影网站| 中文字幕日韩在线观看| 亚洲人成电影网| 亚洲激情国产精品| 精品免费国产二区三区 | 精品奇米国产一区二区三区| 欧美三级韩国三级日本三斤| 亚洲成人精品在线观看| 亚洲嫩草精品久久| 国产精品热久久久久夜色精品三区| 99综合电影在线视频| 成人av动漫在线| 99久久婷婷国产| 99久久综合色| av中文字幕不卡| 91亚洲大成网污www| av电影在线观看一区| 91在线观看免费视频| 93久久精品日日躁夜夜躁欧美| 丁香婷婷综合激情五月色| 国产老女人精品毛片久久| 国产一区二区三区高清播放| 国产一区二区免费在线| 国产成人激情av| 国产在线一区二区综合免费视频| 国产一区二区三区蝌蚪| 成人精品视频网站| 91视频免费看| 国产日产精品一区| 日韩一区有码在线| 亚洲国产综合人成综合网站| 精品久久久视频| 精品视频在线免费| 日韩午夜电影在线观看| 欧美成人r级一区二区三区| 亚洲精品国精品久久99热一| 在线亚洲欧美视频| 欧美精品18videos性欧| 欧美一级淫片丝袜脚交| 国产日本欧美在线观看| 成人免费91在线看| 日本一区二区精品| 欧美一二三不卡| 黄色片在线免费| 黄污在线观看| 在线观看a视频| heyzo高清在线| 免费成人黄色网| 亚洲精品aaaaa| 亚洲一区在线| 免费一区二区视频| av激情亚洲男人天堂| 亚洲免费色视频| 欧美性猛片aaaaaaa做受| 欧美一区二区三区精品| 亚洲小视频在线| 97久久精品国产| 91亚洲精品丁香在线观看| 亚洲国产精品综合| 欧美一区二区三区系列电影| 51精品在线| 日韩精品中文字幕在线播放| 在线日本高清免费不卡| 亚洲综合好骚| 国产成人精品在线看| 中文字幕一区在线| 性欧美video高清bbw| 精品乱人伦小说| 激情在线小视频| 一本久道中文字幕精品亚洲嫩| 久久米奇亚洲| 日本高清免费不卡视频| 黄色影院一级片| 日韩在线中文字幕| 欧美一级大胆视频| 国产精品二区三区| 国产精品无码电影在线观看| 99在线免费观看| 成人影院在线观看| 精品中文字幕一区二区三区四区| 国产精品久久久久蜜臀| 狠狠色丁香婷婷综合| 亚洲理论在线观看| 亚洲丁香久久久| 青青草一区二区| 亚洲自拍偷拍二区| 日本三级电影网| 999av小视频在线| 国内精品久久久久久久影视简单| 日本不卡一区二区| 亚洲欧美日韩精品久久久久| 欧美成人三级电影在线| 91福利视频在线观看| 欧美综合激情| 成人天堂av| 成年人黄色大片在线| 久久91麻豆精品一区| 精品一区二区三区免费播放| 一区二区三区美女视频| 亚洲另类图片色| 91亚洲精品视频| 韩国日本在线视频| 午夜精品一区| 国产厕拍一区| 看电视剧不卡顿的网站| 亚洲va欧美va人人爽| 中文欧美在线视频| 九九九久久久| 激情se五月| 国产精成人品2018| 香蕉久久a毛片|