短函數的優點

来源:http://www.cnblogs.com/androidshouce/archive/2016/06/27/5619144.html
-Advertisement-
Play Games

函數最初的用處 大家剛學編程的時候,一定還記得為什麼要用函數。那就是把重覆的代碼歸納到一個函數中多次利用。這點毋庸置疑,大家也用的很熟了,但是除了這個還有什麼改進空間嗎?答案肯定是有的! PS.本文不討論面向對象、不討論設計模式,只是把視線聚焦在 Class 內部的函數上。 出現什麼問題了? 大家都 ...


函數最初的用處

大家剛學編程的時候,一定還記得為什麼要用函數。那就是把重覆的代碼歸納到一個函數中多次利用。這點毋庸置疑,大家也用的很熟了,但是除了這個還有什麼改進空間嗎?答案肯定是有的!

PS.本文不討論面向對象、不討論設計模式,只是把視線聚焦在 Class 內部的函數上。

 

出現什麼問題了?

大家都知道當一個函數很長的時候,就會造成閱讀困難,那以前我們都是怎麼解決的呢?

  1. 寫註釋:這個大家都知道怎麼用,也是一種有效的方法。
  2. 用 #region 代碼塊:這個也是一個行之有效的方法。

還有什麼別的方法嗎?其實還有一個方法就是文章的標題:使用短函數。

在討論短函數有點之前,我想先用一點篇幅來講述一下什麼時候改寫註釋。

路人甲:納尼?不是說任何時候都要寫註釋嗎?

 

什麼時候該寫註釋

函數主要就有兩個用途:

  1. 在 Class 和 別的函數、欄位、屬性前打三個 / ,就會自動生成供 VS 使用的智能提示內容。
  2. 解釋代碼意圖。

第一點大家都會用,而且就這麼用,沒有什麼替代的辦法。

但是關於第二點,註釋未必是最好的解決辦法。

因為如果一段代碼讓人看不懂,要麼就是“英文看不懂”,要麼就是“邏輯複雜”。

 

註釋是為了彌補它們帶來的缺點,但是為什麼不從根本解決呢?

“英文看不懂”:每個程式員都應該有一定的英文基礎吧?另外註意命名規範,就可以解決了。

“邏輯複雜”:如果一段程式邏輯複雜,讓人看不懂,你覺得你應該費力地去給別人解釋呢?還是自己好好整理整理,把代碼梳理一下呢?

那怎麼梳理你的代碼呢?短函數?

 

短函數的優點——有助於梳理代碼

我想廢話不多說了,都是程式員,大家一看代碼就明白了。

這裡貼上另外一篇文章:《代碼才是最好的註釋》

文章的題目是代碼才是最好的註釋,其實寫的就是短函數的優點。

已經有了文章,我就不重覆工作了。

順便提一下 region ,其實 region 在 VS 下的收縮功能可以達到差不多的效果,你可以選用這個,但是不是很推薦。

下麵,我還要和大家探討一下另一個優點。

 

短函數的優點——在 .Net 下可優化性能

關於這點,我是在《More Effective C#》中看到的,覺得非常好,所以推薦給大家。

把一個大函數拆分成很多小函數可以優化性能?這點看上去很可笑。是的,其實這點性能的提升微不足道,但是如果可以,為什麼不做呢?更何況這樣做還有上面說的另一個優點。

為什麼長函數分割成短函數的時候可以優化 .Net 下的性能呢?

 

你首先要明白:

.Net 下的語言編譯的時候只是編譯成了中間語言。運行的時候,它會再一次編譯成機器碼。

這個中間語言編譯成機器碼是以一個函數為基本代為的。也就是說,每次調用函數的時候,這個函數才會被編譯。

 

那長函數分割成了短函數有優勢嗎?代碼量不還是一樣的?純粹的分割反而會產生更多的代碼呢!

的確如此,所以說,這裡還有另一個條件:當這個長函數中有很多分支的時候。

1 2 3 4 5 6 7 8 9 10 11 public void Func1() {     if(xxxx)     {         //代碼段1,幾百行     }     else     {         //代碼段2,幾百行     } }

上面這段代碼,有兩大段代碼,每次調用這個函數其實只會執行一部分。

所以,如果把這兩塊代碼段提取出來,編譯的過程中就會少編譯一半的代碼。

現在明白在什麼時候把長函數分割成短函數能優化性能了吧。

 

雖然這點性能提升並不明顯,但是,如果你一個函數中,有一個很大的分支。

你在看代碼的過程中,一定會看花眼,滾屏的過程中,都不知道自己現在身處在哪個部分。

隨意就算不考慮性能,也推薦把這樣的代碼分割成短函數!

 

總結

上文說了短函數的優點,說了下註釋的缺陷,還有一個沒怎麼提到的 region …

我在寫代碼的時候一般遵循一下原則:

  1. 函數內部一般不寫註釋,如果“邏輯複雜”,我會優化邏輯並分割成短函數。
  2. 在一些演算法中,包含很奇特的公式,這個一定要寫註釋了,沒辦法分割和優化。
  3. 寫完函數後查看是否有大段的分支,有的話再分割成短函數。

最後,希望本文能對大家有用!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在C#編程中,我們經常需要處理這些情況。 1. 某種條件為真時,程式這樣處理;當某種條件為假時,程式那樣處理。 2. 當某種條件為真時,程式一直這樣處理; 這裡的條件,在C#中就是邏輯運算。接下來我就和大家聊聊C#中關於邏輯運算的一些基本概念。 比較運算符 比較運算符,顧名思議就是用來作比較,比較運 ...
  • 如何運用 Form 表單認證 ASP.NET 的安全認證,共有“Windows”“Form”“Passport”“None”四種驗證模式。“Windows”與“None”沒有起到保護的作用,不推薦使用;“Passport”我又沒用過,唉……所以我只好講講“Form”認證了。我打算分三部分: 第一部分 ...
  • // 舉個例子:一個網站有用戶系統、商家系統、網站後臺3個系統 //可以分3個userType, user ,shop , system //網站後臺一般都有角色,如admin,employee //那麼網站的角色就有 user,shop,admin,employee,但是admin和employe ...
  • 這幾天在看Java的一些東西,除了覺的Java和.NET的相似度實在太高之外,就是Java太原始,急需被拯救。之後又回到.NET的思維來,想著怎麼在框架里實現讀寫分離控制請求切換。之前幾個月一直都有在思考,想及對框架現有的代碼改動可能較大,所以遲遲沒怎麼下手。最近終於在廁所蹲下的一瞬間,靈光一閃,感... ...
  • 我的個人博客站在使用百度富文本編輯器UEditor修改文章時,遇到了一些問題,(不知是bug,還是我沒有配置好)。但總算找到瞭解決方法,在此記錄下來。 小站首頁文章列表顯示為(顯示去除HTML標簽後的前600個字元): 具體在 www.zynblog.com 遇到的問題: 正常來講,進入文章修改頁, ...
  • 在這一個練習中,我們要使用帶返回值的方法。如果一個方法帶返回值,那麼它的形式是這樣的。 定義一個帶返回值的C#方法 static 返回類型 方法名字 (參數類型 參數1的名字,參數類型 參數2的名字) { 你的代碼 return 返回值 } static: 先不用管是什麼意思。在沒有講它的含義之前, ...
  • 最近寫了一個SOA服務,開始覺得別人拿到我的服務地址,然後直接添加引用就可以使用了,結果"大牛"告知不行。 讓我寫一個SOAP調用服務的樣例,我有點愣了,因為沒做過這方面的,於是搞到了一個Demo,然後學習了下。 學習如下: 在.Net中有一個對象:WebRequest它可以在後臺直接請求服務的方法 ...
  • 大家先來看看表單提交的幾種方式: 1、<!--通用提交按鈕--> <input type="submit" value="提交"> 2、<!--自定義提交按鈕--> <button type="Submit">提交</button> 3、<!--圖像按鈕--> <input type="image" ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...