無瑕的程式碼 ─ 整潔的軟體設計與架構篇心得. GitHub Gist: instantly share code, notes, and snippets. ... <看更多>
「無瑕的程式碼:整潔的軟體設計與架構篇」的推薦目錄:
- 關於無瑕的程式碼:整潔的軟體設計與架構篇 在 Re: [請益] 關於clean code書籍選擇- 看板Soft_Job 的評價
- 關於無瑕的程式碼:整潔的軟體設計與架構篇 在 無瑕的程式碼 整潔的軟體設計與架構篇心得 - gists · GitHub 的評價
- 關於無瑕的程式碼:整潔的軟體設計與架構篇 在 設計與架構| Clean Architecture 無瑕的程式碼:整潔的軟體設計 ... 的評價
- 關於無瑕的程式碼:整潔的軟體設計與架構篇 在 More content - Facebook 的評價
- 關於無瑕的程式碼:整潔的軟體設計與架構篇 在 【如何寫乾淨的程式碼? 】程式設計代碼風格指南| 基礎+ 9 個進 ... 的評價
無瑕的程式碼:整潔的軟體設計與架構篇 在 設計與架構| Clean Architecture 無瑕的程式碼:整潔的軟體設計 ... 的推薦與評價
本文為「Clean Architecture 無瑕的程式碼:整潔的軟體設計與架構篇」第1 章「什麼是設計與架構」的閱讀筆記。 ... <看更多>
無瑕的程式碼:整潔的軟體設計與架構篇 在 More content - Facebook 的推薦與評價
無瑕的程式碼 ── 整潔的軟體設計與架構篇https://is.gd/sjg0Af. ... <看更多>
無瑕的程式碼:整潔的軟體設計與架構篇 在 【如何寫乾淨的程式碼? 】程式設計代碼風格指南| 基礎+ 9 個進 ... 的推薦與評價
![影片讀取中](/images/youtube.png)
在我的工作職涯中,我是如何發現應該要寫得 整潔 這件事? ... 拜讀完 無瑕的程式碼 一書後,我整理了一份講義教程,分享給大家裡面會先說明為什麼要有編程 ... ... <看更多>
無瑕的程式碼:整潔的軟體設計與架構篇 在 Re: [請益] 關於clean code書籍選擇- 看板Soft_Job 的推薦與評價
參考個人在約五年前所寫過對「無瑕的程式碼:敏捷軟體開發技巧守則 (中譯本)」一書的書評。
https://www.kenming.idv.tw/bk_clean-code_handbook_software_craftsmanship/
簡而言之,Clean Code 主要必須把持實踐的原則:
1. 對類別、方法、參數、變數賦予有意義的命名。
2. 對程式碼結構持續抱著重構的態度 (重構前一定要撰寫單元測試程式把關):
a). 每一個方法內的陳述控制在 30 行以內 (已是最大極致)。
b). 每一個方法傳遞的參數不得超過5個以內 (參數的資料結構設計議題)。
另,由於原 po 從事 ASP.NET 的開發,這是落在 展示層 (Presentation tier)內的 Web UI 端開發。要切記不要在如 Web Page (View)與 UI Controller 撰寫應用程式邏輯。
關於此點,可以參考個人最近所撰寫的一篇:實作 Enterprise MVC 巨觀結構的 POC-觀念篇
https://www.kenming.idv.tw/implement_enterprise-mvc_macro-view_poc_concept/
要能達成所謂 Clean Code 簡潔的效果,所需要軟體相關的技能,諸如所謂的物件導向觀念、GoF 設計模式的理解與活用、巨觀與微觀結構的設計等,這些是需要在軟體結構面設計的議題持續不斷地學習與體會箇中奧妙了。
======= 書評內容 =======
Clean Code 的原則就是:每一個函式 (function, or method),不超過10行,最好是5行
以內。天啊,這讓我很難以想像,我知道函式不能肥大,也不要有一堆的 if-then-else
or switch 之類的判斷式,但如何縮短為只有10行以內的寫作,我也很難理解。不過細讀
本書內容之後,總算能瞭解要如何作,當然,你更應該體會為何要這麼作。
簡而言之,程式寫作是一門「craftsmanship」,我還蠻喜歡中譯本將之翻為「工藝典範
」。它既要精確,卻也期望將程式寫作昇華為具有美感的作品。我覺得,稍具有良心與審
美觀的程式設計師,絕對不是只有滿足於「可以執行程式」。寫出來程式往往只是起點而
已,持續不斷地精煉 (也就是重構),讓程式整潔,軟體才有可能具彈性與維護性。往往
程式設計師只滿足於讓程式「順利運作」的狀態,有經驗豐富 (還有良心)的程式設計師
,知道那其實是一種專業上的自殺行為。
所以,事實上,寫程式就如同寫散文一般,程式寫得艱澀冗長讓人無法理解,就代表散文
寫作能力不佳。程式設計大師不認為他們在寫程式,而是在說故事。大師利用所選定的程
式語言機制,來幫助建造更豐富更具表達力的語言,讓這個語言可以用來說故事。而簡短
的函式,有意義的命名,以及漂亮的結構,則都有助於描述故事。
當然,要能寫好整潔的程式不是一蹴可幾的,那可是長期性的一種目標與方向。最重要的
應該是意願與職志,然後再來才是學習與鍛鍊應有的觀念與技巧。所以這也是為什麼與其
說程式設計是門科學,不如說程式設計是一門技藝更為貼切。為了要寫整潔的程式碼,你
必須先寫下糟糕的程式,然後去整理它! 對於程式碼,就是要義無反顧的重構它,讓品
質可以改善再提昇至另一個層次。程式如果看待只是一種製造,那麼當重做時就代表著額
外的花費;但當看待為設計,則重做代表的就是創造出價值。
喔,從本書我還學到了唯一最有效度量「程式品質」的單位-WTF (請自行查 Google)。
當 WTF 值越高,程式品質越差,沒有任何例外!
專案管理人員應該要重視這個指標的,絕對沒有其它指標比它更實用有效的。 >_<
所以,到底甚麼是 Clean Code? 為了這個詞彙,作者 Martin 還特別訪問了諸多軟體大師,請他們寫下對 Clean Code 的定義。我比較喜歡 Grady Booch (UML 三巨頭之一) 的解釋:
「Clean Code 是簡單又直接明瞭的,讀來就像一篇優美的散文。
Clean Code 絕不會掩蓋設計者的意圖,反而充滿著俐落的抽象概念,以及直接了當的程式控制敘述。」
其實每一個人應該也會有對 Clean Code 自己的一番解釋。對我而言,Clean Code 就是:
「簡潔有序,層次分明的程式碼。」
※ 引述《geroge0820 (可.....可惡)》之銘言:
: 小弟工作資歷尚淺 前一陣子才轉職
: 目前是用ASP.NET MVC進行網頁開發
: 因為自己還蠻菜的 想加強能力
: 不知道大家都怎麼選clean code的書
: 目前在網路上看到 clean code又是C#實作的是這一本
: 無瑕的程式碼 敏捷完整篇:物件導向原則、設計模式與C#實踐
: 想請問版上的各位 有沒有甚麼建議
--
FB社團:軟體設計鮮思維
https://www.facebook.com/groups/softthinking/
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 114.34.122.227
※ 文章網址: https://www.ptt.cc/bbs/Soft_Job/M.1529470903.A.F8F.html
... <看更多>