成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

做了1000次Code Review,我學到這3點經驗

新聞 前端
Code Review 是保證代碼質量的重要手段。Steven Heidel 曾在 LinkedIn 負責 Code Review,他在本文總結了常見的代碼問題并提出修改方案。

[[314223]]

 Code Review 是保證代碼質量的重要手段。Steven Heidel 曾在 LinkedIn 負責 Code Review,他在本文總結了常見的代碼問題并提出修改方案。

當我在 LinkedIn 工作時,工作的很大一部分內容是做 Code Review。在這個過程中,我發現一些人很容易犯的錯誤,于是把錯誤整理起來并分享給團隊。

經驗 1:當出現錯誤時 Throw an exception

我看到的一個常見模式是:

  1. List<String> getSearchResults(...) { 
  2.   try { 
  3.     List<String> results = // make REST call to search service 
  4.     return results; 
  5.   } catch (RemoteInvocationException e) { 
  6.     return Collections.emptyList(); 
  7.   } 

上面的方法可能是很多新手工程師的做法,但這種模式會有問題。在我曾經參與的移動應用中,這種模式導致移動應用程序的故障。用戶搜索開始后,我們的后端發生錯誤開始 throwing exceptions,但在應用程序的 API server 中并沒有 throwing exceptions。

因此,從應用角度看,前端會收到 200 個成功的響應,然后顯示空白的搜索結果給使用者,而團隊卻毫不知情。

如果 API  thrown an exception,那我們的監控系統會立刻發現它,并能及時修復。

很多時候,當捕捉到異常后,我們傾向于返回 empty object。Java 中 empty object 的樣例包括 Optional.empty()、null 和 empty list。這種情況經常發生在 URL 解析中。如果 URL 無法從字符串解析得到的話,不要返回 null,而要問問自己:

URL 格式為什么是不合法的?這是一個需要在 upstream 解決的數據問題嗎?

對于這種任務來說,empty object 并不是恰當的工具。如果出現異常行為,那么就應該 throw an exception。

經驗 2:盡可能使用最具體的類型(type)

基本而言,這條建議恰好與 stringly typed programming 相反。

我經常看到下面所示的代碼:

  1. void doOperation(String opType, Data data);  
  2. // where opType is "insert", "append", or "delete", this should have clearly been an enum 
  3.  
  4. String fetchWebsite(String url); 
  5. // where url is "https://google.com", this should have been an URN 
  6.  
  7. String parseId(Input input); 
  8. // the return type is String but ids are actually Longs like "6345789" 

用最具體的類型 (type)可以避免很多 bug。

現在問題是:好心的程序員為什么會寫出糟糕的 stringly typed 代碼?

答案在于外部世界不是強類型的。字符串有很多不同的來源,比如:

  • url 中的查詢和路徑參數
  • JSON
  • 不支持枚舉的數據庫
  • 編寫糟糕的庫

在上述場景中,我們應使用如下的策略來避免該問題:將字符串解析和序列化放在程序的邊緣之處。

下面是這樣一個樣例:

  1. // Step 1: Take a query param representing a company name / member id pair and parse it 
  2. // example: context=Pair(linkedin,456) 
  3. Pair<String, Long> companyMember = parseQueryParam("context"); 
  4. // this should throw an exception if malformed 
  5.  
  6. // Step 2: Do all the stuff in your application 
  7. // MOST if not all of your code should live in this area 
  8.  
  9. // Step 3: Convert the parameter back into a String at the very end if necessary 
  10. String redirectLink = serializeQueryParam("context"); 

這種方式有很多優點。立即發現格式錯誤的數據;如果出現任何問題,應用程序將提前 fails。數據被驗證一次后,不必在整個應用程序中繼續捕獲解析異常。

此外,強類型使方法簽名更具描述性,我們不再需要在每個方法上編寫那么多的 javadocs。

經驗 3:用 Optionals 而非 nulls

Java 8 帶來最棒的特性之一是Optional類,它代表一個可能存在也可能不存在的實體。

一個小問題:

唯一擁有自己縮寫的例外(exception)是什么?答案是 NPE 或空指針異常。截至目前,它是 Java 中最常見的異常,并被稱為價值 10 億美元的錯誤 (https://www.infoq.com/presentations/Null-References-The-Billion-Dollar-Mistake-Tony-Hoare )。

Optional能讓我們完全從程序中移除 NPE。但是,必須以正確的方式使用它。如下是關于使用Optional的一些建議:

  • 我們不能在得到Optional的任何時候都簡單地調用它的.get(),相反,我們要仔細考慮Optional不存在的情況并給出一個合理的默認值;
  • 如果還沒有合理的默認值,那么像.map()和.flatmap()這樣的方法允許我們推遲到以后再做決定;
  • 如果外部庫返回null來表示為空的情況,那么立即使用Optional.ofNullable()wrap 該值。相信我,你以后會感謝自己的。null 值在程序內部有“bubble up”的傾向,所以最好在源代碼中停止它們;
  • 在方法的返回類型中使用Optional。這種做法非常好,因為我們不需要讀取 javadoc 來確定值是否可能不存在。

額外建議:盡可能采用“Unlift”方法

我們應避免下面所示的方法:

  1. // AVOID: 
  2. CompletableFuture<T> method(CompletableFuture<S> param); 
  3. // PREFER:  
  4. T method(S param); 
  5.  
  6. // AVOID: 
  7. List<T> method(List<S> param); 
  8. // PREFER: 
  9. T method(S param); 
  10.  
  11. // AVOID:  
  12. T method(A param1, B param2, Optional<C> param3); 
  13. // PREFER: 
  14. T method(A param1, B param2, C param3); 
  15. T method(A param1, B param2); 
  16. // This method is clearly doing two things, it should be two methods 
  17. // The same is true for boolean parameters 

上述不推薦使用的方法有哪些共同點?那就是它們都使用了 container objects 作為參數,比如 Optional、List 或 Task。

如果返回類型是相同種類的 container,那就更糟糕了(比如,param methods 接收 Optional,返回值也是 Optional)。

為什么呢?

1)Promise<A> method(Promise<B> param)要比 2)A method(B param)更缺少靈活性。

如果有一個Promise<B>的話,我們可以用 1),也能通過.map函數使用 2)(即promise.map(method))。

但是,如果只有一個 B 的話,我們很容易使用 2),但是無法使用 1),這樣來看,2) 是更具靈活性的方案。

我喜歡將其稱為“unlifting”,因為它與常見的函數式工具方法“lift”恰好相反。采用這種方式重寫會讓方法更具靈活性,對調用者更加易用。

 

責任編輯:張燕妮 來源: 架構頭條
相關推薦

2021-04-27 10:02:40

股票數組代碼

2020-12-25 09:38:07

Vue前端代碼

2018-08-16 15:11:47

Code ReviewPPT代碼

2020-05-19 13:46:33

勒索軟件信息安全攻擊

2015-11-17 16:11:07

Code Review

2022-10-27 10:33:48

敏捷開發開發

2018-05-25 17:10:20

谷歌溝通經驗

2013-10-24 09:43:58

代碼代碼審查

2012-07-05 09:45:02

代碼審查

2010-12-02 11:01:23

職場經驗

2019-02-28 09:53:21

IT互聯網職場

2009-08-05 09:59:40

Code Review代碼審查工具

2021-04-25 09:19:22

騰訊Code Reviewleader

2021-08-09 06:57:41

CodeReview流程

2024-11-08 14:18:38

2017-07-20 13:11:46

Code ReviewPR評審

2012-09-03 13:41:50

Code Review

2015-04-15 09:44:58

CodeReview程序員

2014-04-15 13:16:00

Code Review

2020-05-27 11:25:48

開發技能代碼
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品一区av | 97国产精品视频 | 中文字幕视频免费 | 国产日韩视频 | 亚洲av毛片 | 亚洲精品成人网 | 在线观看亚洲 | 久久成人免费视频 | 亚洲午夜av | 日本又色又爽又黄又高潮 | 91成人免费看 | 国产精品久久久久久一级毛片 | 午夜精品久久久久久久星辰影院 | 久久99久久98精品免观看软件 | 性欧美xxxx | 一区二区视频 | 一区二区在线免费播放 | 亚洲综合区 | 久久久精品 | 免费黄网站在线观看 | 国产成人亚洲精品 | 亚洲日韩第一页 | 欧美精品一区三区 | 久久国产高清视频 | 精品亚洲国产成av人片传媒 | 久久尤物免费一区二区三区 | 日批免费观看 | caoporn国产精品免费公开 | 亚洲色图综合 | 538在线精品 | 偷拍亚洲色图 | 黑人巨大精品欧美一区二区免费 | 91精品国产91久久久久青草 | 亚洲日韩中文字幕一区 | 亚洲狠狠 | 欧美精三区欧美精三区 | 91不卡| 国产精品美女www爽爽爽视频 | 国内自拍视频在线观看 | 久久久精品一区 | 91成人精品 |