久久天堂一区二区三区_国内精品久久久久影院网站_亚洲国产一区二区三区最新_亚洲国产一区二区三区四区五区

每位開發人員都應銘記的10句編程諺語



北大青鳥通州校區提供:

1. 無風不起浪

代碼設計是否糟糕,從某些地方就可以看出來。比如:
a. 超大類或超大函數
b. 大片被注釋的代碼
c. 邏輯重復
d. If/else嵌套過深
程序員們通常稱它們作代碼異味(Code Smell),但是就我個人認為“代碼警報”這個名字更為合適一些,因為它有更高的緊迫感的含義。根本問題處理不當,終將引火燒身。

譯注:Code Smell中文譯名一般為“代碼異味”,或“代碼味道”,它是提示代碼中某個地方存在錯誤的一個暗示,開發人員可以通過這種smell(異味)在代碼中追捕到問題。

2. 預防為主,治療為輔

20世紀80年代,豐田公司的流水作業線因為它在缺陷預防方法上的革新變得出了名的高效。每個發現自己的部門有問題的成員都有權暫停生產。這個方法意在寧可發現問題后馬上暫定生產、解決問題,也不能由其繼續生產而導致更棘手且更高代價的修復/更換/召回后的問題。

程序員總會做出生產率就等同于快速編碼的錯誤臆斷。許多程序員都會不假思索地直接著手代碼設計。可惜,這種LeeroyJenkins式魯莽的做法多會導致軟件的開發過程變得很邋遢,拙劣的代碼需要不斷的監測和修改——也可能會被徹底地替換。最終,生產率所涉及到的因素就不僅僅是寫代碼所消耗的時間了,還要有調試的時間。稍不留神就會“撿了芝麻丟了西瓜”。(因小失大。)

譯注:Leeroy Jenkins 行為:WOW游戲中一位玩家不顧大家獨身一人迎敵,導致滅團。

3. 不要孤注一擲 (過度依賴某人)

一個軟件開發團隊的公共要素(bus factor)是指那些會影響整個項目進程的核心開發人員的總數。比如某人被車撞了或某人生孩子或某人跳槽了,項目可能就會無序,甚至會擱置。

譯注: bus factor 即指公共要素,比喻了開發過程中的一些共同因素。如果擠上 bus 的 factor 越多,bus 就越不穩定,所以要控制好 bus factor ,以免問題發生。

換句話說,如果你的團隊突然失去了一個主力成員,你會怎么辦?生意依舊進行還是戛然而止?

很不幸,大多數軟件團隊都陷入了后一種情況。這些團隊把他們的開發人員培養成了只會處理他們自己專業領域的“領域專家”。起初,這看起來是一個比較合理的方法。它對汽車制造裝配生產線很適用,但是為什么對軟件開發團隊就不行呢?畢竟,想讓每個成員都掌握所編程序的細微差別也不太可能,對吧?

問題是開發人員不容易輕易替換掉。雖然當每位成員都可用時,“抽屜方法”很有效,但如果當“領域專家”突然因人事變動、疾病或突發事故而無法工作時,抽屜方法立馬土崩瓦解。所以,軟件團隊有一些看似多余實則重要的后備力量是至關重要。代碼復查、結對編程和共有代碼可用成功營造一個環境,在這個環境中,每位開發人員至少表面上是熟悉自己非擅長領域之外的系統部分。

4. 種瓜得瓜,種豆得豆

《注重實效的程序員》一書中有這樣一段話解釋“破窗理論”:不要留著“破窗戶”(低劣的設計、錯誤的決策或者糟糕的代碼)不修。發現一個就修一個。如果沒有足夠的時間進行適當的修理,就先把它保留起來。或許你可以把出問題的代碼放到注釋中,或是顯示“未實現”消息,或用虛擬數據加以替代。采取一些措施,防止進一步的惡化。這表明局勢尚在掌控之中。

我們見過整潔良好的系統在出現“破窗”之后立馬崩潰。雖然促使軟件崩潰的原因還有其他因素(我們將在其他地方接觸到),但(對“破窗”)置之不理,肯定會更快地加速系統崩潰。

簡而言之,好的代碼會促生好的代碼,糟糕的代碼也會促生糟糕的代碼。別低估了慣性的力量。沒人想去整理糟糕的代碼,同樣沒人想把完美的代碼弄得一團糟。寫好你的代碼,它才更可能經得住時間的考驗。

譯注:《注重實效的程序員》,作者Andrew Hunt / DavidThomas。該書直擊編程陳地,穿過了軟件開發中日益增長的規范和技術藩籬,對核心過程進行了審視――即根據需求,創建用戶樂于接受的、可工作和易維護的代碼。本書包含的內容從個人責任到職業發展,直至保持代碼靈活和易于改編重用的架構技術。從本書中將學到防止軟件變質、消除復制知識的陷阱、編寫靈活、動態和易適應的代碼、避免出現相同的設計、用契約、斷言和異常對代碼進行防護等內容。

譯注:破窗理論(BrokenWindowtheory):是關于環境對人們心理造成暗示性或誘導性影響的一種認識。“破窗效應”理論是指:如果有人打壞了一幢建筑物的窗戶玻璃,而這扇窗戶又得不到及時的維修,別人就可能受到某些暗示性的縱容去打爛更多的窗戶。發現問題就要及時矯正和補救。

5. 欲速則不達

經理、客戶和程序員正日益變得急躁。一切都需要做的事,都需要馬上就做好。正因如此,快速修復問題變得非常急迫。

沒時間對一個新功能進行適當的單元測試?好吧,你可以先完成一次測試運行,然后你就可以隨時回來繼續測試它。

當訪問Y屬性時,會不會碰到奇怪的對象引用錯誤?無論怎樣,把代碼放到try/catch語句塊中。我們要釣到大魚啦!

是不是似曾相識呢?這是因為我們在以前已經都做到了。并且在某些情況下、它是無可非議的。畢竟,我們有最后期限,還得滿足客戶和經理。但不要過于頻繁操作,否則你會發現你的代碼不穩定,有很多熱修復、邏輯重復、未測試的方案和錯誤處理。最后,你要么是把事情草草做完,要么是把事情好好做完。

6. 三思而后行

“敏捷開發”這個詞最近被頻繁濫用,經常被程序員用來掩飾他們在軟件開發過程中的糟糕規劃/設計階段。我們是設計者,看到產品朝正當方向有實質進展,我們理應高興。但意外的是,UML圖和用例分析似乎并不能滿足我們的愿望。所以,在不知自己做什么的情況下或者不知自己身處何處時,我們開發人員經常就稀里糊涂地寫代碼了。

這就好比你要去吃飯,但你根本沒有想好去哪里吃。因為你太餓了,所以你迫不及待地找個餐館,定個桌位。然后你上車開車后沿途在想(找地方吃飯)。只是,這樣會耗費更多的時間,因為你要過較多的U型彎道,還在餐館前停車,也許最后因等待時間過長而不吃了。確切地說,你最后應該能找到地方吃飯,但你可能吃的飯并不是你想吃的,并且這樣花費的時間,可能比你直接在想去的餐館訂餐所花的時間更長。

7. 如果你惟一的工具是一把錘子,你往往會把一切問題看成釘子

程序員有一種傾向,當一談到他們工具時,其視野就變狹窄了。一旦某種方法在我們的一個項目上“行得通”,我們就會在接下來所有的項目上都用到它。學習新東西仿佛是一種煎熬,有時候甚至會心神不定。從始至終都在想“如果我用之前的方法做、這個就不會這么麻煩了”。一定要摒棄這種想法,按我們所知道的去做,即使那不是最完美的解決方法。

堅持自己所知很簡單,不過從長遠的角度講,選擇一個適合這項工作的工具要容易得多。否則,就會與你的職業生涯格格不入。

8. 沉默即贊同

"破窗理論"與"變成慣性理論"有著宏觀的聯系。

編程社區就好像一個現實社區。每個作品都是一個開發者的縮影。糟糕的代碼發布的越多,就越容易反映現狀。如果你不去努力編寫優秀、整潔和穩定的代碼,那你每天都將和糟糕的代碼相伴了。

同樣地,如果你看到別人寫出了糟糕的代碼,你就要跟這個人提出來。注意,這時候機智就應該用上場了。一般情況下,程序員都愿意承認他們在軟件開發中還是有不懂的地方,并且會感謝你的好意。互相幫助對大家都有利,而對問題視而不見,只會使問題一直存在。

9. 雙鳥在林,不如一鳥在手

如果可以討論系統架構和重構,那么就差找個時間把事情做完。為了使正常運作的東西更加簡潔而做改動,權衡改動的利弊很重要。當然了,簡潔是一個理想目標,但總會有可以通過重構改進的代碼。在編程世界中,為了代碼不過時,會頻繁簡單改動代碼。但有時候你又必須保證代碼對客戶有價值。那么,你面臨一個簡單窘境:你不能一石二鳥。你在重構舊代碼上所花時間越多,你編寫新代碼的時間就越少。在及時改進代碼和維護程序之間,也需要找到平衡點。

10. 能力越大,責任越大

毫無疑問,軟件已成為我們生活中一個既基本又重要的一部分。正因如此,開發優秀軟件格外重要。乒乓球游戲中的Bug是一回事,航天飛機導向系統或者航空交通管制系統中的Bug是另外一回事。Slashdot曾發表一文,講述了單單Google News的一個小失誤使一家公司股票蒸發11.4億美元。其他例子參見《軟件Bug引發的十次嚴重后果》。這些例子便說明了我們正行使著多大的權利。你今天寫的代碼,無論你是否有意,說不定有朝一日在重要的應用程序中派上用場,這想想都令人害怕。編寫正確合格的代碼吧!

譯注:Slashdot是一個資訊科技網站。

北大青鳥網上報名
北大青鳥招生簡章
久久天堂一区二区三区_国内精品久久久久影院网站_亚洲国产一区二区三区最新_亚洲国产一区二区三区四区五区

      9000px;">

          亚洲国产视频a| 日韩久久一区二区| 91视频xxxx| 国产精品一二一区| 国产中文字幕一区| 九九国产精品视频| 久久精品国产亚洲a| 韩国在线一区二区| 国产精品亚洲成人| 不卡视频一二三| kk眼镜猥琐国模调教系列一区二区 | 成人看片黄a免费看在线| 国产综合色在线视频区| 国产精品一线二线三线精华| 懂色av中文一区二区三区| 国产a区久久久| 99视频一区二区三区| 欧美伊人久久久久久午夜久久久久| 欧美日韩一区不卡| 日韩区在线观看| 精品久久国产字幕高潮| 久久精品人人做人人综合| 日韩一区欧美小说| 午夜精品免费在线| 激情另类小说区图片区视频区| 国产综合色视频| av电影天堂一区二区在线观看| 欧美日韩二区三区| 久久久久国色av免费看影院| 中文字幕一区二区三区四区| 三级久久三级久久久| 国产乱一区二区| 在线视频观看一区| 久久久久久久久久电影| 一区二区三区四区在线免费观看| 日本在线观看不卡视频| 成人免费视频一区二区| 欧美电影在哪看比较好| 国产欧美一区二区精品性| 亚洲一二三四在线| 国产河南妇女毛片精品久久久 | 日韩欧美在线综合网| 中文在线资源观看网站视频免费不卡 | 久久99最新地址| 97国产一区二区| 欧美成人vr18sexvr| 一区二区三区在线观看动漫| 韩国三级在线一区| 欧美日韩不卡在线| 中文字幕精品—区二区四季| 免费观看91视频大全| 日本精品一级二级| 国产日韩av一区二区| 日韩国产精品大片| 欧美午夜一区二区| 亚洲三级小视频| 国产精品中文字幕欧美| 欧美一个色资源| 亚洲国产精品久久人人爱| 99久久久久久| 国产欧美精品在线观看| 久久国产精品第一页| 91精品国产欧美一区二区成人| 亚洲精品va在线观看| av不卡在线观看| 国产三级精品视频| 国内精品在线播放| 精品黑人一区二区三区久久| 日韩在线观看一区二区| 欧美午夜一区二区三区免费大片| 亚洲欧美视频一区| 91老司机福利 在线| 久久久久久久综合色一本| 免费的成人av| 91精品国产aⅴ一区二区| 丝袜脚交一区二区| 欧美精品123区| 日韩av中文字幕一区二区三区| 欧美色网一区二区| 亚洲高清中文字幕| 777奇米成人网| 午夜激情一区二区| 欧美一区在线视频| 狠狠色丁香久久婷婷综合_中 | 午夜伊人狠狠久久| 欧美精品 日韩| 青青草一区二区三区| 日韩午夜精品视频| 国产一区二区三区综合| 日本一区二区成人在线| 成人高清伦理免费影院在线观看| 国产精品久久二区二区| 91免费视频观看| 午夜精品一区二区三区电影天堂 | 国产乱码精品一品二品| 欧美激情一区二区在线| 成人av资源站| 亚洲国产裸拍裸体视频在线观看乱了| 日本韩国欧美三级| 蜜臀精品一区二区三区在线观看 | 婷婷国产在线综合| 欧美一区二区三区日韩视频| 亚洲综合成人在线视频| 日韩无一区二区| 国产aⅴ综合色| 亚洲自拍欧美精品| 欧美电影免费观看高清完整版在线 | 国产综合色在线视频区| 中文字幕不卡一区| 欧美影院精品一区| 国产一区三区三区| 一区二区三区成人| 欧美白人最猛性xxxxx69交| 国产成人精品免费| 亚洲国产一区视频| 久久精品亚洲国产奇米99| 99久精品国产| 蜜臀va亚洲va欧美va天堂| 国产欧美精品在线观看| 欧美日韩一区二区在线视频| 国产在线看一区| 亚洲一区二区四区蜜桃| 欧美哺乳videos| 91电影在线观看| 国产成人综合在线观看| 午夜激情一区二区| 欧美激情综合网| 欧美一区二区三区四区高清| 91在线免费看| 国产精品亚洲视频| 日韩精品成人一区二区三区| 亚洲欧洲日韩在线| 久久久精品国产免大香伊| 欧美日韩精品专区| voyeur盗摄精品| 国产老肥熟一区二区三区| 天天做天天摸天天爽国产一区| 1024成人网| 国产精品久久99| 国产日韩v精品一区二区| 日韩精品专区在线影院重磅| 欧美日韩国产首页| 欧美午夜电影在线播放| 91麻豆国产香蕉久久精品| 成人免费视频视频| 国产.欧美.日韩| 风间由美一区二区三区在线观看| 寂寞少妇一区二区三区| 日韩专区一卡二卡| 亚洲成a人在线观看| 亚洲国产精品麻豆| 亚洲午夜久久久久久久久久久| 亚洲桃色在线一区| 中文字幕中文字幕在线一区| 国产精品视频观看| 欧美激情自拍偷拍| 国产亚洲欧美一区在线观看| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 91久久人澡人人添人人爽欧美| 精品av久久707| 国产精品影视天天线| 亚洲精品日日夜夜| 欧美日韩国产色站一区二区三区| 国产精品三级av| 欧美色综合天天久久综合精品| 日本不卡一区二区| 欧美日韩在线免费视频| 午夜激情一区二区| 欧美体内she精高潮| 色狠狠桃花综合| 国产成人精品亚洲777人妖| 日韩成人一区二区三区在线观看| 久久久国产一区二区三区四区小说| 亚洲精品乱码久久久久久| 亚洲最快最全在线视频| 欧美成人一区二区三区片免费| 欧美亚洲图片小说| 欧美日韩成人激情| 欧美日韩欧美一区二区| 国产69精品久久99不卡| 国模一区二区三区白浆| 久久久久久日产精品| 免费看日韩精品| 婷婷一区二区三区| 亚州成人在线电影| 国产精品美女久久久久久久久| 欧美日韩久久一区二区| 色综合久久综合中文综合网| thepron国产精品| 国产精品亚洲视频| 精品一区二区在线视频| 亚洲第一主播视频| 综合分类小说区另类春色亚洲小说欧美| 欧美色精品天天在线观看视频| 欧美日韩综合在线| 欧美精品在线观看播放| 在线看国产一区二区| 欧美一级片在线观看| 欧美日韩另类一区| 日韩免费高清av|