資料介紹
過度封裝是程序員最容易犯的錯, 因為是否過度并沒有固定的數值標準, 只能是有經驗的程序員基于科學的判斷。過度封裝的危害十分嚴重, 所以必須重視, 并且極力避免。
首先, 什么是“過度封裝”? 我們知道, 計算機科學領域最稱為經典也是最強大的思想便是遞歸, 分而治之。但是, 遞歸本身最重要的因素是: 結束條件。 一生二, 二生三, 三生萬物, 總要有終止的條件吧? 不然一輛車不停地急馳, 你怎樣上車?
新手程序員, 特別是非科班出身的文科程序員, 最容易犯了過度封裝的錯誤的原因就是不知道何時適可而止, 腦筋往往不斷地分解分解再分解問題, 最后, 你看到的就是這個調用那個, 那個引用這個, 亂七八糟毫無頭緒, 三兩行代碼的函數比比皆是, 自以為封裝抽象, 其實是拿捏不好這個度。
一旦過度封裝, 直接的危害往往是寫了無數行代碼, 封裝了N多個類, 就是看不出一個完整的功能, 因為分裂起來收不住。即使最終把功能實現了, 代碼維護性也讓人不忍直視。
如何判斷是否過度封裝? 如何避免過度封裝? 我認為, 只要掌握了一個原則, 時刻以這個原則為準繩, 那便幾乎不會犯過度封裝的錯誤。
這個原則便是“直觀優先”原則, 代碼邏輯以直觀為最優先的原則, 其它的原則均低于此原則, 即使有一百個考慮, 如果違反了直觀原則, 都必須放棄掉而優先保證直觀原則。
舉一個例子:
function closeDialog() { login.close(); message.close(); 。。.close(); } var action = { close: function () { closeDialog(); }, backout: function () { if (BACKOUT_ID) { 。。. } } }; $(document).on(’click‘, function (e){ var $that = $(e.target); for ( var k in action) { if ( $that.hasClass(’action-‘+k) ) { action[k].call(e.target); } } });
這樣的代碼就是過度封裝的經典體現!
首先, closeDialog() 這個函數不應該存在, 而應該被展開, 因為函數只被調用一次, 而且沒有邏輯上的獨立性的必要。
其次, 上面的函數通過跳轉表的方式來逃避直接的函數調用, 這是對跳轉表技術的極大濫用! if-else 加函數調用是最直觀的分支跳轉方式, 完全沒有必要在這個例子里使用跳轉表技術。
先解釋一下什么是跳轉表技術, 這是一個非常古老而基礎的計算機編程領域的技術。跳轉表包含很多層含義, 簡單的說, 就是將邏輯代碼塊放到一個索引表中, 代碼編寫過程通過傳遞索引項來最終調用相應的邏輯代碼塊(因為多處引用)。
第一次聽到或者見到跳轉表技術的程序員的心情, 如果你想體驗的話, 你想想當你寫了無數的 if-else 之后, 你發現了 switch-case 時的心情, 或者是你第一次聽到函數指針這個事物時的心情。
但是, 像 js 之類高級語言, 已經把跳轉表技術, 直接融合到了語言的語法本身, 如類(class)。 你不需要實現自己的跳轉表技術, 你只需要用好語言本身的特性即可。
所以, 上面的代碼應該改成:
$(document).on(’click‘, function (e){ var $that = $(e.target); if ( $that.hasClass(’action-close‘) ) { login.close(); message.close(); 。。.close(); } if ( $that.hasClass(’action-backout‘) ) { if (BACKOUT_ID) { 。。. } } });
這是最直觀, 最正常, 人人都應該寫成這樣的代碼。如果你還想顯式地使用查找表技術以體現自己牛逼, 我是說, 如果你真想裝逼的話, 你可以這樣寫:
var action = { close: function () { login.close(); message.close(); 。。.close(); }, backout: function () { if (BACKOUT_ID) { 。。. } } }; $(document).on(’click‘, function (e){ var $that = $(e.target); var func_name = $(that).attr(’action‘); if(func_name && action[func_name]){ action[func_name](); } });
如果都這樣寫了, 那和直接在 html 標簽里寫 onclick 屬性有什么區別? 難道通過 class 綁定事件就高級, 寫 onclick 指明回調函數的名字就不高級了?
所以我勸你最好不要裝逼也別裝傻, 乖乖地有理有據有邏輯地寫代碼, 讓代碼的邏輯直觀起來, 不要過度封裝。如果你內心封裝的欲望太強的話, 那我勸你學學 Go 語言, 把自己的思想強加到一種自己新發明的語言上來(我估計你沒那種本事)。不然, 直觀優先, 不要過度封裝。
- 程序員表白程序
- ISI 程序員指南
- 打開 LNS 程序員參考
- LNS 程序員指南
- ISI 程序員指南
- LNS 程序員指南
- 程序員的浪漫《Rice DIY設計》
- 程序員如何規劃自己的成長之路
- 程序員必備專用單詞快來學習吧! 22次下載
- 程序員需要學什么,微軟資深程序員學習手冊面試寶典資料 30次下載
- 程序員羊皮卷下載版(程序員必備) 0次下載
- 程序員2011第5期 0次下載
- 程序員2011第9期 0次下載
- 程序員2011第11期 0次下載
- ADO程序員指南
- 5款程序員最佳的代碼比較工具 5331次閱讀
- 六款程序員必看的前端在線開發工具 2689次閱讀
- 怎樣提升程序員的硬核實力?關于程序員的未來發展 1877次閱讀
- 盤點Java程序員不能錯過的7個基本框架,完美構建復雜應用 2979次閱讀
- 程序員為什么記不住所有的代碼如何解決這個問題 7100次閱讀
- 程序員需要知道的那些定理和法則 3020次閱讀
- 程序員值得一看的9本學習算法經典書籍 4w次閱讀
- 華為資深工程師:程序員與碼農的差異在哪? 3620次閱讀
- 一個電子發燒友的程序員成長之路 6751次閱讀
- 對技術的執著和美的追求變成了程序員的“詩和遠方” 1962次閱讀
- 數據顯示:中國程序員是世界上最牛的程序員 606次閱讀
- 碼農和程序員之間就在這5個關鍵點! 596次閱讀
- 我們對技術的依賴有多強?程序員為何關注它? 983次閱讀
- 程序員真正的價值是什么? 1609次閱讀
- 嵌入式程序員需要了解的幾個問題 1248次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費下載
- 0.00 MB | 1490次下載 | 免費
- 2單片機典型實例介紹
- 18.19 MB | 92次下載 | 1 積分
- 3S7-200PLC編程實例詳細資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關電源原理及各功能電路詳解
- 0.38 MB | 10次下載 | 免費
- 6基于AT89C2051/4051單片機編程器的實驗
- 0.11 MB | 4次下載 | 免費
- 7藍牙設備在嵌入式領域的廣泛應用
- 0.63 MB | 3次下載 | 免費
- 89天練會電子電路識圖
- 5.91 MB | 3次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費
- 4LabView 8.0 專業版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費
- 5555集成電路應用800例(新編版)
- 0.00 MB | 33562次下載 | 免費
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費
- 8開關電源設計實例指南
- 未知 | 21539次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537791次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191183次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183277次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138039次下載 | 免費
評論
查看更多