精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

郭昂:漫談重構

開發 架構
首先重構面臨的背景都是相似的,程序員們為了快速完成需求和上線而寫出了最基本的代碼,而在功能的不斷擴充過程中,以打補丁的方式對代碼進行擴充,中間還會面臨著開發人員的變更和離職。逐漸的,代碼就會越來越臃腫,漸漸的變得難以維護。

因為工作內容的原因,我在前后兩家公司中的工作中主持和經歷了十余次代碼和架構的重構,下面隨便說說我對重構的一些經驗和想法。

關于重構

首先重構面臨的背景都是相似的,程序員們為了快速完成需求和上線而寫出了最基本的代碼,而在功能的不斷擴充過程中,以打補丁的方式對代碼進行擴充,中間還會面臨著開發人員的變更和離職。逐漸的,代碼就會越來越臃腫,漸漸的變得難以維護。

糟糕的架構會有什么樣的影響?首先是開發效率的降低,在糟糕架構下加進新功能,會受之前代碼的影響,可能存在意想不到的改動點和問題點,開發和調試時間都會大大增加;其次是故障率的提升,在質量低下的代碼中,總是容易藏著很多不易發現的坑,這些都會成為故障的隱患;同時,架構也會使得需求的完成大打折扣,使得設計好的目標,因為架構限制或者性能等原因,只能完成80%甚至更低。

重構要解決的問題

重構不能憑空重構,一定是要解決一個問題,一般情況下重構要解決的問題大致有以下幾種:

·結構糟糕。相信很多碼農們,都遇到過接手別人的代碼后都感到撓頭的事情,五千行以上的文件,三千行以上的函數,面對這樣子的代碼,對其進行修改和繼續開發是件很艱難的事情。

·安全隱患。很多代碼,都只是為了功能上快速完成,而對很多潛在的安全風險置之不管,如內存管理、異常處理、模塊接口等。有的雷如果不掃,可能遲早有一天會爆發。

·性能問題。對于很多大型服務,性能高一點可以節省很多的服務器費用。性能問題主要需要找到核心問題,有的問題出在架構,而大多出代碼上。

·功能擴展。有的模塊,開始設計時只是實現一些很基本的功能,而隨著產品功能不斷增強,被賦予了越來越復雜的功能,到了一定程度,需要進行重構以讓其能夠實現新賦予的任務。

·協同開發。很多時候,一個大系統往往需要多個人一起進行開發,如果需要這些人改同一個類甚至同一個函數,往往是沖突不斷,而代碼的整合往往也會存在更多問題。這時候需要很好的架構能夠支持多人的共同開發和修改。

·模塊調試。在一個大系統中,往往有很多子模塊互相關聯,而假如某個模塊的調試需要啟動整個大系統,或者會受到其他模塊穩定性的影響,對于效率是非常低的。而重構建立調試層或者開發調試工具是更好的選擇。

·模塊復用。有些時候,多個系統或算法,可能會用到子算法和子模塊,而不同項目或模塊重復開發相同功能的子模塊,在很多公司都很常見。而很多時候,將一些公共的部分抽象出來,能夠將這部分做的更好更精,而從整體上,往往能大幅度提高開發效率和效果,往往也能優化算法性能。

·算法使用不當。在有些模塊中,使用了不恰當的數據結構或者相關算法,使得或者是性能,或者是效果出現了問題。這種情況,甚至要將原有的體系結構推到重來,重新設計算法和數據結構,達到盡可能好的匹配效果。

·承載規模不夠。對于一些系統,都有其設計的容納規模,例如瞬間訪問量、同時在線人數,很多公司從小到大都經歷過這個過城,當超過一定量級時,很多時候并非簡單通過加服務器能解決,有時需要重新設計架構。就像12306,因為架構問題使得很難承擔過高的瞬時在線人數。

重構經驗感受

重構時,第一道難關是如何過領導這道關。很多領導都要背著產品指標和任務,大多人也更關心其能夠在多長時間做出什么,重構這種事情,在很多時候,有可能是“費力不討好”的代名詞,因為在大多情況,無法幫助領導完成指標。這種情況下,如何獲得領導的支持就極其重要了。

對于重構,一種方法是,讓重構與某些技術或產品指標掛鉤,例如完成新產品、改進效果、提高性能等,相當于是重構伴隨著其他改進搭幫上線,那么這種情況可以比較順利的完成重構。

而如果單純的為了架構的合理性而去重構的話,就需要去說服領導,為什么原來的架構會降低開發效率,新做的架構能帶來哪方面的提升。一定要讓領導明白,這個能帶來實實在在的長期收益,不管性能、效率、安全等都可以,而并非只是“看著不爽”而進行的重構。

如果團隊規模有一定的人的話,也可以分出一部分進行新型架構的開發,而另一部分人在現有架構上進行改進,使得短期目標和長期目標兩不耽誤。這時候,值得注意的就是,不管從代碼還是設計角度上來看,都要讓現有做的事情能夠復用,而不是新架構上線之后就會被廢掉。

如何進行漸進式重構,也是很多架構師需要去思考的問題。就是不搞一下子半年一年的重構,而是以月為單位,快速的迭代,能夠很快的看到效果,并且小規模投入使用。

不管怎樣,重構,一定不能是為了重構而重構,或者對前人的代碼看著不爽,或者抱有技術完美主義而進行重構,最重要是找準其要解決的實際問題,這時候的重構,能帶來的是開發效率上的提升。

而在重構的過程中,也需要做好新架構的設計,并且擁有一定的前瞻性,否則很容易出現新架構、新新架構、新新新架構這樣子的事情。另外,也要盡可能的增強代碼的復用性,讓其中的模塊,在任何一個架構中都能夠很好的被應用,當然這個要根據具體情況具體分析。

對于重構,也盡量不要擁有技術完美主義。很多時候,使用最成熟的方案及最簡單的架構模型實現所需要的功能一般來說更加“簡單可依賴”,有的時候架構過于復雜反而喧賓奪主,因為所有架構都是為了功能服務的。同時,也盡量不要使用很多未經廣泛使用的前沿技術,因為這些在開發和部署過程中,很多都可能會遇到意想不到的問題,延緩開發速度并影響線上效果。

此外,作為重構時的負責人,一定要緊跟代碼開發的過程,并隨時進行指導,一般情況下,不要相信寫出糟糕代碼的人,經過略加指導就能寫出漂亮代碼了。我曾經有過這樣的經歷,要將一個超大的類按照功能進行模塊化拆分,設計好了架構及每個子模塊就讓組員進行開發。開發完了我看代碼時登時就抓狂了,模塊是拆分了,每個功能也都建立好了子類,并通過主類調用子類,但是每個子類又都將主類作為友元,又去調用主類里面的成員變量和函數。這種代碼,再次重構也是難免的,這個給我的經驗教訓就是,重構的工作一定要做細,迭代中的代碼檢查也是必不可少的。

良好的習慣,從最初做起

當然,重構再怎么樣,也是一種推翻重做,耽誤時間的做法。從我的經驗來看,其實大多數的重構都是可以避免的,這需要從以下幾個方面去提高。

良好的編碼風格,好的習慣往往很難是天然形成的,更多是在工作中不斷的老帶新中耳濡目染練出來的。很多領導希望員工全部時間都用來做項目,不斷地去壓更多的活,實際上是在用跑短跑的方式跑長跑,很容易出現后勁不足的情況。而我在微軟的經歷,也讓自己感受到了從潮手到逐漸成熟的過程,后來在搜狗時即使再忙沒法搞team review,我也會去盡量給每個組員檢查他們的代碼,幫助別人去提高。

初期的架構設計,這個也是非常重要的。架構設計能不能一次到位,這個不太好說。但是相信好的架構,一定比粗糙的設計能夠堅持更長得多的時間。并且好架構可以考慮到未來可能擴充的規模和功能,為未來的發展留好接口。同時在其中所有的模塊都非常有序,即使大的框架要修改的話,也只是搭一個架子,原有的子功能和子模塊都能夠被很好的復用。

其實很多時候,代碼并非要開發一陣就重構一次,而寫出好的架構,也并非是那么難。更重要的是,需要的是不斷的提高程序員的自我修養,不僅僅是能力上的,還有態度上的。不要只想最初開發時省事,而不考慮若干時間后的事情。好的架構,對未來的開發以及發展,可以說是真真實實的“事半功倍”。

最后,我們看一個關于扁鵲的故事:

魏文王曾求教于名醫扁鵲:“你們家兄弟三人,都精于醫術,誰是醫術最好的呢?”扁鵲:“大哥最好,二哥差些,我是三人中最差的一個。”  魏王不解地說:“請你介紹的詳細些。”

扁鵲解釋說:“大哥治病,是在病情發作之前,那時候病人自己還不覺得有病,但大哥就下藥鏟除了病根,使他的醫術難以被人認可,所以沒有名氣,只是在我們家中被推崇備至。我的二哥治病,是在病初起之時,癥狀尚不十分明顯,病人也沒有覺得痛苦,二哥就能藥到病除,使鄉里人都認為二哥只是治小病很靈。我治病,都是在病情十分嚴重之時,病人痛苦萬分,病人家屬心急如焚。此時,他們看到我在經脈上穿刺,用針放血,或在患處敷以毒藥以毒攻毒,或動大手術直指病灶,使重病人病情得到緩解或很快治愈,所以我名聞天下。”

扁鵲實際上就是一個很好的重構高手,但是扁鵲的大哥,就是因為能夠將問題看在前面,處理在前面,所以能夠永葆健康,這更是高手中的高手!

原文鏈接:http://blog.sina.com.cn/s/blog_6592c40501018e9y.html

責任編輯:張偉 來源: 新浪博客
相關推薦

2013-08-26 20:01:26

XTools信息化管理

2022-03-01 17:26:35

華為數字化

2014-10-28 14:23:11

微昂

2020-02-26 08:16:32

AIoT人工智能物聯網

2013-05-15 15:05:53

2012-12-21 12:37:24

2012-05-15 01:16:19

開發重構Java

2019-06-29 14:40:10

能源物聯網IOT

2010-07-06 16:19:02

協議封裝

2010-06-21 15:06:45

AMF協議

2017-02-20 17:41:12

SDN網絡

2021-08-03 08:13:48

重構API代碼

2015-07-14 10:58:02

SDNNFVNV

2018-02-07 15:25:41

2010-07-08 13:23:14

SAN路由協議

2010-07-08 14:25:12

HART協議

2010-03-01 17:25:12

Python 測試框架

2015-09-15 09:20:22

Neutron技術虛擬化
點贊
收藏

51CTO技術棧公眾號

欧美美女在线直播| 美乳视频一区二区| 欧美成人另类视频| 国产精品亲子伦av一区二区三区| 国产精品国产三级国产aⅴ入口| 91亚洲精品在线| 亚洲伊人成人网| 久久久9色精品国产一区二区三区| 精品国产乱码久久久久久老虎| 久久久999视频| 麻豆av在线免费看| 91视频国产资源| 91久久国产精品| 无码人妻精品一区二区| 欧美精品首页| 色av中文字幕一区| 37p粉嫩大胆色噜噜噜| 欧美电影在线观看一区| 日韩欧美精品免费在线| 男插女免费视频| 美女毛片在线看| 国产成人aaaa| 农村老熟妇乱子伦视频| 91精彩视频在线观看| 国产电影精品久久禁18| 日本最新高清不卡中文字幕| 中文字幕人妻一区二| 蜜桃一区二区| 精品国产区一区| 午夜国产福利在线观看| 日韩欧美看国产| 五月激情六月综合| 996这里只有精品| 日本高清中文字幕在线| 久久精品亚洲麻豆av一区二区 | 久久精品一区二区三区四区五区| 日韩极品在线| 亚洲大胆人体视频| 在线观看视频在线观看| 成人国产精品入口免费视频| 五月婷婷综合激情| 成人免费视频91| 午夜小视频在线观看| 中文字幕在线免费不卡| 日韩一区国产在线观看| 日本中文字幕一区二区有码在线| 成人小视频在线| 成人黄动漫网站免费| 国产绿帽刺激高潮对白| 九九久久精品视频| 国产日韩欧美综合| 伊人亚洲综合网| 美洲天堂一区二卡三卡四卡视频| 国产成人综合一区二区三区| 天天操中文字幕| 模特精品在线| 日本久久亚洲电影| 中文字幕69页| 日韩高清欧美激情| 国产精品视频一| 一级黄色短视频| 国产在线国偷精品免费看| 91嫩草在线视频| 国产黄a三级三级看三级| 国产一区二区三区日韩| 999视频在线免费观看| 国产成人精品a视频| 国产精品2024| 国产午夜精品一区| 毛片在线能看| 亚洲国产精品99久久久久久久久 | 欧美日韩一区二区三区| 少妇无码av无码专区在线观看| 国产白浆在线免费观看| 欧美视频免费在线观看| mm1313亚洲国产精品无码试看| 成人亚洲免费| 欧美一区三区四区| 波多野结衣加勒比| 国产日产一区| 久久影院免费观看| 日本一区二区欧美| 噜噜噜躁狠狠躁狠狠精品视频| 国产精品视频公开费视频| 99产精品成人啪免费网站| 成人国产精品视频| 日韩一区国产在线观看| 中文在线免费| 欧美午夜视频在线观看| 日本高清久久久| 成人搞黄视频| 中文字幕日韩在线播放| 久操视频免费在线观看| 久久精品三级| 97超碰人人看人人| 国内在线精品| 一区二区三区高清| 日本激情视频在线| 97品白浆高清久久久久久| 亚洲欧美一区二区三区四区 | 国产精品二区不卡| 国内精品伊人久久| 在线免费观看日韩视频| 波多野结衣精品在线| 亚洲成人一区二区三区| 丁香高清在线观看完整电影视频 | 自拍偷拍 国产| 99精品国产一区二区三区2021| 亚洲男人天堂手机在线| 久操视频免费在线观看| 日本美女视频一区二区| 国产精品久久久久久免费观看 | 91av视频在线观看| 国产女人18毛片水18精| 久久人人爽人人爽| 久久久性生活视频| 国产麻豆一区二区三区| 日韩麻豆第一页| 草视频在线观看| 蜜桃一区二区三区四区| 明星裸体视频一区二区| 草草影院在线| 日韩欧美色综合网站| 91久久久久久久久久久久久久| 久久久精品午夜少妇| 国产精品久久久久久久天堂第1集| 在线观看免费版| 一本一道久久a久久精品| www男人天堂| 午夜精品久久| 成人免费看片视频| 婷婷成人激情| 欧美日韩中文另类| 日韩av片在线| 老司机午夜免费精品视频| 黄色99视频| 青草在线视频| 欧美大片拔萝卜| 欧美激情精品久久| 国产一区二区中文字幕| 亚洲第一综合网站| 欧美xxxx网站| 久久久精品国产网站| 曰批又黄又爽免费视频| 中文字幕高清一区| 中文字幕 91| 日韩欧美综合| 国产欧美精品在线播放| 91福利在线视频| 欧美亚洲国产bt| 欧美日韩生活片| 蜜臀va亚洲va欧美va天堂| 亚洲欧美国产精品桃花| 成人在线免费电影网站| 日韩中文字幕欧美| ,一级淫片a看免费| 亚洲色图欧美在线| 三上悠亚 电影| 国精品一区二区三区| 国产免费一区二区三区| 麻豆蜜桃在线观看| 亚洲色图综合久久| 一级片在线观看视频| 日韩久久一区二区| 亚洲欧美激情一区二区三区| 欧美三级免费| 久久综合九九| 电影亚洲一区| 欧美精品制服第一页| 国模私拍视频在线| 一本一本久久a久久精品综合麻豆| 亚洲AV无码成人精品区明星换面| 美女视频一区二区三区| 99re6这里有精品热视频| 国产一区二区三区不卡av| 26uuu日韩精品一区二区| 好吊视频一二三区| 亚洲乱码视频| 免费99视频| 久久精品国产精品亚洲毛片| 播播国产欧美激情| 秋霞在线观看一区二区三区| 国产成人77亚洲精品www| 久久艳片www.17c.com| 免费观看黄色一级视频| 色狠狠一区二区| √天堂中文官网8在线| 成人福利视频在线| 天天天干夜夜夜操| 欧美日韩精品一本二本三本| 免费观看国产成人| japansex久久高清精品| 8x拔播拔播x8国产精品| 日本在线免费网| 亚洲黄页网在线观看| 中文字幕欧美在线观看| 亚洲国产日韩a在线播放性色| 亚洲精品成人无码熟妇在线| 精品一区免费av| 自慰无码一区二区三区| 综合激情网站| 日韩av高清| 玖玖玖免费嫩草在线影院一区| 国产精品免费一区豆花| 国产精品69xx| 日韩视频免费在线观看| 嫩草精品影院| 亚洲第一av网| 国产精品丝袜黑色高跟鞋| 欧美性猛交xxxx乱大交3| 免费毛片在线播放免费| 国产欧美久久久精品影院| 日韩女优在线视频| 狠狠色丁香婷婷综合久久片| 国产视频一视频二| 欧美国产91| 一区二区日本伦理| 国产伦精品一区二区三区千人斩 | av中文字幕第一页| 欧美性受极品xxxx喷水| 国产成人在线播放视频| 一区二区欧美视频| 欧美激情图片小说| 国产精品免费视频网站| 波多野吉衣中文字幕| 成人手机电影网| 台湾佬美性中文| 激情综合色综合久久| 国产九九在线视频| 三级精品在线观看| 国产精品亚洲αv天堂无码| 9国产精品视频| 久无码久无码av无码| 91精品国产成人观看| 亚洲一区二区三区四区中文| 精品久久美女| 色播五月综合| 日韩免费视频| 五月天亚洲综合情| 第一sis亚洲原创| 亚洲 国产 日韩 综合一区| 美女久久久久| 日本在线观看一区二区| 国产精品亚洲二区| 色综合久久88色综合天天提莫| 国产日韩欧美一区二区三区| 日本在线视频不卡| 久久高清精品| 小说区视频区图片区| 在线免费观看日本欧美爱情大片| 婷婷视频在线播放| 久久久久久久久久久妇女| 99精品视频网站| 欧美精品啪啪| 国产av国片精品| 欧美日韩电影一区二区| 黄色18在线观看| 18性欧美xxxⅹ性满足| 精精国产xxxx视频在线野外| 欧美亚洲日本网站| 天天免费亚洲黑人免费| 国产精品久久久久久久久久尿 | 欧美在线free| 夜夜躁狠狠躁日日躁av| 欧美一级免费大片| 成人久久精品人妻一区二区三区| 亚洲成人国产精品| 国产福利小视频在线观看| 中文字幕亚洲精品| 伊人春色在线观看| 91精品国产91久久久久久最新| 丝袜美腿一区| 成人激情免费在线| 国产精品调教视频| 四虎永久国产精品| 欧美激情日韩| 日本在线观看a| 久久99最新地址| 日本三级日本三级日本三级极| 久久久久久久免费视频了| 无码人中文字幕| 亚洲福利视频导航| 国产精品国产精品国产| 日韩欧美一区二区在线视频| 深夜福利在线看| www国产亚洲精品久久网站| 欧美aaa免费| 国产精品偷伦一区二区 | 日本中文在线一区| 韩国av免费在线观看| 94色蜜桃网一区二区三区| 精品无码在线观看| 亚洲三级视频在线观看| 日韩av大片在线观看| 精品视频一区三区九区| 精品人妻无码一区二区三区蜜桃一| 亚洲娇小xxxx欧美娇小| 青青草手机在线| 中文字幕在线观看日韩| 91超碰在线| 国产欧美va欧美va香蕉在线| 国产香蕉精品| 宅男噜噜99国产精品观看免费| 激情久久久久久久| jizz18女人| av不卡在线观看| 成人无码av片在线观看| 亚洲高清三级视频| 中文字幕在线观看1| 日韩av影视在线| 欧美性猛交xxx乱大交3蜜桃| 国内精品久久久久久中文字幕| 日日夜夜一区| 久久福利电影| 日韩欧美字幕| 超碰影院在线观看| 成人av网站在线| 69av视频在线| 欧美日韩国产一二三| 午夜福利视频一区二区| 欧美床上激情在线观看| 成人做爰视频www| 欧美成人综合一区| 国产中文一区| 成人黄色一级大片| 中文字幕精品三区| 黄色大片网站在线观看| 欧美一区二区观看视频| av电影在线网| 国产精品www网站| 国产探花在线精品一区二区| 精品国产一区二区三区无码| 国内精品久久久久影院薰衣草 | 在线播放成人av| 亚洲男女性事视频| 国产无遮挡裸体视频在线观看| wwwxx欧美| 综合国产精品| 无码人妻一区二区三区精品视频| 国产精品不卡一区二区三区| 天天爱天天做天天爽| 国产午夜精品免费一区二区三区| 97蜜桃久久| 成人h猎奇视频网站| 99久久亚洲精品蜜臀| 久久99999| **性色生活片久久毛片| 亚洲资源在线播放| 精品国产一区二区三区久久狼黑人| 欧美一级二级视频| 日韩精彩视频| 久久99精品国产.久久久久久| 免费视频91蜜桃| 欧美日韩成人在线一区| 日韩黄色影院| 91精品视频在线看| 婷婷另类小说| 日本高清一区二区视频| 中文字幕一区二区三区精华液 | 国产av 一区二区三区| 91精品国产欧美日韩| 影音先锋中文在线视频| av一区二区在线看| 91精品二区| 荫蒂被男人添免费视频| 精品久久久久久电影| 国产一二三区在线视频| 国产精品久久久久久久久久ktv| 久久精品播放| 久久久久久久久久久久久久久国产| 国产精品三级在线观看| 国产裸体永久免费无遮挡| 欧美刺激性大交免费视频| 校园春色另类视频| 久久精品香蕉视频| 国产精品卡一卡二| 黄色一级大片在线免费看国产一| 久久久久久久一区二区| 色棕色天天综合网| 不卡的av中文字幕| 午夜视频在线观看一区二区 | 亚洲人午夜精品| 国产精选久久| 成人在线免费在线观看| 国产精品久久久久久一区二区三区| 91精品国自产| 欧美人交a欧美精品| 国产综合久久久| 激情久久综合网| 色综合久久99| www久久日com| 欧美性色黄大片人与善| 久久99精品久久久久久| 日本在线观看视频网站| 日日噜噜噜夜夜爽亚洲精品| 最新国产精品精品视频| 一区二区三区视频在线观看免费| 亚洲另类在线一区| 超碰免费97在线观看| 国产精品jizz视频|