天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

每個程序員都必須遵守的編程原則

  本文是從 The Principles of Good Programming 這篇文章翻譯而來。

  好的編程原則跟好的系統設計原則和技術實施原則有著密切的聯系。下面的這些編程原則在過去的這些年里讓我成為了一名優秀的程序員,我相信,這些原則對任何一個開發人員來說,都能讓他的編程能力大幅度的提高,能讓他開發出可維護性更強、缺陷更少的程序。

  不要自我重復(DRY - Don’t repeat yourself)—— 這也許是在編程開發中最最基本的一個信條,就是要告訴你不要出現重復的代碼。我們很多的編程結構之所以存在,就是為了幫助我們消除重復(例如,循環語句,函數,類,等等)。一旦程序里開始有重復現象的出現(例如很長的表達式、一大堆的語句,但都是為了表達相同的概念),你就需要對代碼進行一次新的提煉,抽象。

  http://en.wikipedia.org/wiki/Don%27t_repeat_yourself

  提煉原則(Abstraction Principle) ——跟“不要自我重復”原則相關,這一原則是說“程序中任何一段具有功能性的代碼在源代碼文件中應該唯一的存在。”

  http://en.wikipedia.org/wiki/Abstraction_principle_(programming)

  保持簡單 ——簡單化(避免復雜)永遠都應該是你的頭等目標。簡單的程序讓你寫起來容易,產生的bug更少,更容易維護修改。

  http://en.wikipedia.org/wiki/KISS_principle

  不要開發你目前用不到的功能 ——除非你真正需要用到它,否則不要輕易加上那些亂七八糟用不到的功能。

  http://en.wikipedia.org/wiki/YAGNI

  用最簡單的方法讓程序跑起來 ——在開發時有個非常好的問題你需要問問自己,“怎樣才能最簡單的讓程序跑起來?”這能幫助我們在設計時讓程序保持簡單。

  http://c2.com/xp/DoTheSimplestThingThatCouldPossiblyWork.html

  不要讓我動腦子 ——這實際上是Steve Krug 關于web界面操作的一本書的書名,但也適用于編程。主旨是,程序代碼應該讓人們花最小的努力就能讀懂和理解。如果一段程序對于閱讀者來說需要花費太多的努力才能理解,那它很可能需要進一步簡化。

  http://www.sensible.com/dmmt.html

  開放/封閉原則 ——程序里的實體項(類,模塊,函數等)應該對擴展行為開放,對修改行為關閉。換句話說,不要寫允許別人修改的類,應該寫能讓人們擴展的類。

  http://en.wikipedia.org/wiki/Open_Closed_Principle

  為維護者寫程序 ——任何值得你編寫的程序在將來都是值得你去維護的,也許由你維護,也許由他人。在將來,當你不得不維護這些程序時,你對這些代碼的記憶會基本上跟一個陌生人一樣,所以,你最好還是當成一直在給別人寫程序。一個有助于你記住這個原則的辦法是“寫程序時時刻記著,這個將來要維護你寫的程序的人是一個有嚴重暴力傾向,并且知道你住在哪里的精神變態者”。

  http://c2.com/cgi/wiki?CodeForTheMaintainer

  最少意外原則 ——最少意外原則通常是使用在用戶界面設計上,但這個原則同樣適用于編寫程序。程序代碼應盡可能的不要讓閱讀者感到意外。也就是說應該遵循編碼規范和常見習慣,按照公認的習慣方式進行組織和命名,不符常規的編程動作應該盡可能的避免。

  http://en.wikipedia.org/wiki/Principle_of_least_astonishment

  單一職責原則 ——一個代碼組件(例如類或函數)應該只執行單一的預設的任務。

  http://en.wikipedia.org/wiki/Single_responsibility_principle

  最小化耦合關系 ——一個代碼片段(代碼塊,函數,類等)應該最小化它對其它代碼的依賴。這個目標通過盡可能少的使用共享變量來實現。“低耦合是一個計算機系統結構合理、設計優秀的標志,把它與高聚合特征聯合起來,會對可讀性和可維護性等重要目標的實現具有重要的意義。”

  http://en.wikipedia.org/wiki/Coupling_(computer_programming)

  最大化內聚性 ——具有相似功能的代碼應該放在同一個代碼組件里。

  http://en.wikipedia.org/wiki/Cohesion_(computer_science)

  隱藏實現細節 ——隱藏實現細節能最小化你在修改程序組件時產生的對那些使用這個組件的其它程序模塊的影響。

  http://en.wikipedia.org/wiki/Information_Hiding

  笛米特法則(Law of Demeter) ——程序組件應該只跟它的直系親屬有關系(例如繼承類,內包含的對象,通過參數入口傳入的對象等。)

  http://en.wikipedia.org/wiki/Law_of_Demeter

  避免過早優化 ——只有當你的程序沒有其它問題,只是比你預期的要慢時,你才能去考慮優化工作。只有當其它工作都做完后,你才能考慮優化問題,而且你只應該依據經驗做法來優化。“對于小幅度的性能改進都不該考慮,要優化就應該是97%的性能提升:過早優化是一切罪惡的根源” — Donald Knuth。

  http://en.wikipedia.org/wiki/Program_optimization

  代碼復用 ——這不是非常核心的原則,但它跟其它原則一樣非常有價值。代碼復用能提高程序的可靠性,節省你的開發時間。

  http://en.wikipedia.org/wiki/Code_reuse

  職責分離 ——不同領域的功能應該由完全不同的代碼模塊來管理,盡量減少這樣的模塊之間的重疊。 

  http://en.wikipedia.org/wiki/Separation_of_concerns

  擁抱變化 ——這是Kent Beck的一本書的副標題,它也是極限編程和敏捷開發方法的基本信條之一。很多的其它原則都基于此觀念:面對變化,歡迎變化。事實上,一些經典的軟件工程原則,例如最小化耦合,就是為了讓程序更容易面對變化。不論你是否采用了極限編程方法,這個原則對你的程序開發都有重要意義。

  http://www.amazon.com/gp/product/0321278658

it知識庫每個程序員都必須遵守的編程原則,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 一本色道久久综合亚洲AV蜜桃 | 久久毛片免费看一区二区三区 | 久久精品AV无码亚洲色欲 | 无码国产成人777爽死在线观看 | 色欲久久精品AV无码 | 日韩 无码 手机 在线 | 成年人免费在线视频观看 | 2020国产成人精品免费视频 | 99热在线精品免费全部my | 99国产强伦姧在线看RAPE | 内射人妻无码色AV麻豆去百度搜 | 高跟丝袜岳第一次 | 欧美人与善交大片 | 给个男人都懂的网址2019 | 亚洲综合小说久久另类区 | 最近日本MV字幕免费观看视频 | 亚洲欧美强伦一区二区另类 | 伊人国产在线视频 | 就去色一色 | 色综合欧美色综合七久久 | 国产一区二区不卡老阿姨 | 高H内射NP古文| 久久re这里视频只有精品首页 | 野草在线视频完整视频 | 探花口爆颜射乳交日韩 | 超碰v| 久久er国产精品免费观看2 | 同桌上课把奶露出来给我玩 | 亚洲欧美精品无码一区二在线 | 国产传媒在线观看 | 国产美女视频一区二区二三区 | 动漫成人片 | 亲伦在线观看 | 国产 高清 无码 中文 | 毛片在线不卡 | 国产精品成人啪精品视频免费观看 | 国产在线AV一区二区香蕉 | 久久永久影院免费 | 国内精品视频久久久久免费 | 在线自拍综合亚洲欧美 | 一区二区不卡在线视频 |