0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

一位做了十年開發(fā)工程師總結的經(jīng)驗

工程師人生 ? 來源:網(wǎng)絡整理 ? 作者:工程師4 ? 2018-06-01 18:49 ? 次閱讀

做開發(fā)十年,我總結出了這些開發(fā)經(jīng)驗

在一線做了十年的開發(fā),經(jīng)歷了網(wǎng)易、百度、騰訊研究院、MIG 等幾個地方,陸續(xù)做過 3D 游戲、2D 頁游、瀏覽器、移動端翻譯 app 等。

積累了一些感悟。必然有依然幼稚的地方,就當拋磚引玉,聊為笑談。

一、對于團隊而言,流程太重要了

行軍打仗,你需要一個向?qū)В蝗绻麤]有向?qū)?,你需要一個地圖;如果沒有地圖,至少要學習李廣,找一匹識途的老馬;如果你連老馬也沒有,那最好可以三個臭皮匠好好討論,力圖勝過一個諸葛亮;如果三個臭皮匠連好好討論也做不到,那就是典型的烏合之眾了,最好寫代碼前,點上三炷香,斟上一杯濁酒,先拜拜菩薩,再拜拜谷歌。

我個人屬于性格溫和的(程序員大多性格不錯),但確實見過少數(shù)強勢的人,說很多強勢的話。在技術上一言而決,一聽到任何反對就上升到私人恩怨。這樣的風格,到底是剛愎自用,還是胸有成竹,就需要仔細判斷了。

為什么說流程重要呢?實際上,如果團隊上有孫悟空存在,去西天取經(jīng),大概也不需要什么流程,只要方向就可以了。 但作為普通的戰(zhàn)士,應該先慮敗。找人算命時,應該先聽聽不好的地方,好的地方就不用聽了,總歸是好的,不好的地方一定要聽,這樣才能規(guī)避。

這就是我的態(tài)度:先悲觀一點,劃清底線,考慮在這個底線上你該怎么做?

這是我做開發(fā)的一個習慣,但這個習慣肯定不適用于買房。怎么劃清底線呢?就是假想團隊中沒有孫悟空了,光靠你唐玄奘、豬八戒和沙和尚,應該怎么去取經(jīng)。

這個月走什么地方,遇到山怎么走,遇到河怎么過,遇到路上有妖怪劫道,誰去抵擋。遇到路上有少女要搭救,怎么辦?這就是流程,是原則。

我經(jīng)歷過一個流程很混亂的階段。都是很多年前的事情了,可以拿出來說說,不涉及單個人。

2011年在百度瀏覽器團隊時遇到幾件讓人影響深刻的事情。 有一次開會,產(chǎn)品拿出 Google 某個產(chǎn)品的 DEMO,里面有一段很酷炫 3D 效果,要求開發(fā)加上,只給2天時間,大家目瞪口呆。后續(xù)的開發(fā)為了趕節(jié)奏,導致非常多的 bug ,又為了修改 bug ,leader 將所有的 bug 按照人員平均分配,導致不同模塊間的同學相互修改。..。..實在難以想象。好比讓做花卷的廚子,去修改西湖醋魚的味道。

最初的現(xiàn)象是:bug下降的慢,延伸 bug 反而增加,每個人都累的半死,代碼風格極其雜亂,為了趕工導致的臨時方案層出不窮;

到了中期:人員離職越來也多,代碼難以維護,新加的需求與之前的臨時方案沖突。

到了后期:想做一些修復,想調(diào)整架構,又要保證正常運行,其難度好比在一架飛行的飛機上拆換零件。

然后我也急忙離職了。..。..實在看不到成功的可能性。

后來到了騰訊的團隊,感覺流程就規(guī)范多了。需求和 bug 有 Tapd 跟蹤,產(chǎn)品發(fā)布按照節(jié)奏,需求提出前會和開發(fā)反復討論可行性,有專門的質(zhì)量跟蹤,有專門的用戶反饋,每天知道要做什么,也知道明天要做什么。有產(chǎn)品需求,也有開發(fā)需求!這個非常重要。很多團隊,都是只有產(chǎn)品需求,開發(fā)好像牛一樣,耕完地就不管了?

流程其實沒那么復雜,就是各司其責+節(jié)奏。我們都是“哆瑞咪發(fā)梭拉西多”中的一員,各自有各自的責任,然后組合在一起,按照一個節(jié)奏跑起來。把該做的事情與該跑的節(jié)奏定好。

二、不要炫技,老老實實寫代碼

網(wǎng)上有一個段子,說有人要用JS實現(xiàn)一個簡單的功能,然后朋友給他推薦了幾十個庫。

真的有必要嗎?具體情況具體分析。

居家過日子,你只需要一套普通的工具就可以了;如果你是修車的,你需要一套修車的工具;如果你是光頭強,你需要一臺伐木機。 吃飯用筷子,用刀叉,都可以,但不要用殺豬刀,不要用丈八長矛!,當然也不能用牙簽。

用什么工具,用什么庫,問問過來人,多在KM上搜索一下。舉個例子:android 上加密,用 SQLChpher就可以了,微信也在用,你當然可以學習;數(shù)據(jù)庫 ORM 思想,用 KM 上推薦的 GreenDAO 就可以了;PC 上 3D 引擎,用OGRE就可以了;小型游戲 DEMO,用 Irrlicht 足夠;寫 WebGL,用 ThreeJS 足夠。

首先想想:一些大庫 hold 的住嗎,后續(xù)發(fā)展如何?這些庫對安裝包的體積影響有多大?有沒有調(diào)研過同樣的產(chǎn)品在用什么?

想清楚了再決定用什么,最好是跟隨成功項目的腳步。

三、架構上實用+適用

很喜歡曾國藩的一句話:結硬寨、打呆仗。

一字長蛇陣、八門金鎖陣,哪個好?iOS 都是單個進程,微信 Android 版本3.5以前是單進程,3.5以后有獨立的網(wǎng)絡進程; PC 瀏覽器的進程架構更加復雜,UI 進程、內(nèi)核進程、Render 進程,而且還有根據(jù)頁面多少的進程調(diào)節(jié)模型。

這些設計都很好,各有各的道理,都適用于當前的產(chǎn)品。所以我的觀點是:首先分析當前產(chǎn)品的規(guī)模、性質(zhì),然后再設計架構。

在當前階段達到:開發(fā)效率+架構的平衡;并向后展望3個月,或者半年左右,看看架構能不能適應。

我做騰訊翻譯君時,曾反復猶豫要不要模仿微信加入獨立的網(wǎng)絡進程。后來逆向了有排在第一二位的競品,最終采用了現(xiàn)在的主功能單進程模型。

產(chǎn)品規(guī)模、人員規(guī)模、功能階段,具體問題具體分析。

四、既要有攻城之力,也要有熬戰(zhàn)之氣——BUG

產(chǎn)品開發(fā)完成后,必然有 bug 。其實開發(fā)人員在工作過程中,是有一定的直覺或者心理預判的,即:某個功能模塊的質(zhì)量如何。 這里面的質(zhì)量包括:可維護性、擴展性、算法渲染效率,還有就是bug與崩潰率。

功能開發(fā)完成后,就要開始守城了。

bug,一部分產(chǎn)生是由于架構帶來的,例如比較復雜的架構,會導致復雜的實現(xiàn)細節(jié);

但還有很大部分bug,其實是基于如下三個原因產(chǎn)生的:

對于某個api的不了解,或者對于某個平臺,或者 SDK 版本的不了解。 舉例而言:android里面非主線程,是不能直接處理UI相關的事情的;JAVA 的內(nèi)存釋放也不是絕對的,相互指向是無法釋放的;函數(shù)個數(shù)是有DEX問題制約的---------------------這些bug的產(chǎn)生,也是開發(fā)人員摸索學習的過程,經(jīng)歷過一次就不會再犯了。這是學習廣度與熟練度的問題;

還有一些bug,是由于粗心大意導致的。例如空指針的問題,野指針的問題。在 C 的開發(fā)中,野指針的問題,GDI 句柄的釋放問題,這些都是嚴謹?shù)拇a需要避免的; 而又一些工具,或者方法是可以規(guī)避這些問題的,例如 android中 的利用@ Nullable 和@ NonNull 加強空指針檢測等方法;

還有一些bug,是由于“使用情況各異導致的”。例如:偶現(xiàn)在某個模塊crash。這里的本質(zhì)還是因為邏輯的異常邊界沒有處理好。例如 android 上的 OOM 問題,還有 PC 上 UI 焦點導致的對象釋放問題。這些異常情況,一部分靠測試發(fā)現(xiàn),一部分靠用戶反饋,還有一部分就靠自己的異常處理。例如Android中的try catch機制,其實就是遇到異常了,你能糾正錯誤的機會。

五、自審

每過一段時間,都要站在高空俯視自己,問問:到底是在承擔過去,還是在改變未來。

如果之前程序代碼質(zhì)量不好,后面修改問題的時間就會比較多。到了開發(fā)的中期,得多問問自己,你在不停的改正以前的錯誤,還是在做新的東西。 如果修改錯誤的時間多一點,那就要注意自己的代碼質(zhì)量了!

六、注釋

我很喜歡寫注釋。有大牛說:代碼就是最好的注釋。 可惜我還沒有達到那個程度。所以,我會把注釋寫的非常清楚。其一:為了自己以后維護的方便; 其二:為了其他人接手的方便。

這是我在翻譯君項目中寫注釋的方式。1:對于很復雜的邏輯,務必用12345的順序依次寫清楚;2 :對于函數(shù)中的某個參數(shù),需要解釋為什么要設置這個參數(shù),尤其是公用工具類里面的函數(shù)---說清楚參數(shù)的背景含義,可以讓其他調(diào)用者理解的更加清晰。

我一般不用英文寫。雖然這樣看起來格調(diào)很低,但勝在大家都能輕松的看懂。寫代碼不能太傲嬌,寫注釋也不要太傲嬌,目的是讓你的搭檔或者接手者,更輕松的理解,讓她/他少加班。

七、代碼結構

代碼結構要清晰。有按照功能劃分的,有按照 UI 結構劃分的。還有公用工具類,有數(shù)據(jù)管理,有主邏輯控制。不管用哪種思想,有序的代碼結構,可以讓每個人感覺很干凈。好比日本的收納整理技巧讓很多小資推崇,無非就是干凈、整潔、便于管理。

而且,還有一個重要的好處:代碼結構表現(xiàn)出來的其實是——程序的一個模塊邏輯思想——讓大家工作在不同的區(qū)域。

八、代碼風格

代碼風格統(tǒng)一!好比一家人,有叫 Tom 的,有叫安東尼的,還有叫流川楓、石破天、圣杰夫拉斯基,無所適從。理論上,看一個函數(shù),就能從名稱上區(qū)分哪些是成員變量,哪些是局部變量,哪些是全局靜態(tài)值。

除了命名統(tǒng)一外,還有一行代碼最大的寬度,函數(shù)的連續(xù)調(diào)用長度等,頭文件的包含風格,也最好有一個約定。類的出現(xiàn)時間,創(chuàng)建人名,最好也加上,看起來沒用,但到了追蹤問題時,就能看出時間線的好處。

九、安全與逆向

這是針對Android說的,還有PC插件也需要考慮。Android 上首先要防止被別人逆向,我成功逆向并重新打包過有第一位和第二位的競品。這似乎有點不可思議,但確實做到了。加固+混淆+代碼判斷,最好都有。

安全上,可以看金剛掃描的漏洞,逐一修改就行。公司很多工具很好用的!

十、開發(fā)效率

開發(fā)效率可以用這些方式提升:

構建公用工具類,方便大家使用。

使用開源的一些包,例如 ORM 思想的數(shù)據(jù)庫等。

可以很快的找到問題。開發(fā)中,找 bug 的時間,往往是很多的。我用的方法有3個: 使用 try catch; 攔截所有 crash 到我指定的地方;超多的 Log,Log 有統(tǒng)一的控制開關。

借力:數(shù)據(jù)上報用燈塔,崩潰上報用 bugly,公司 KM 上很多經(jīng)驗,拿過來用。

十一、安裝包體積

TINY 壓縮圖片

刪除無效的資源文件

十二、UI渲染效率

UI 是用戶的第一感覺;UI 快并穩(wěn)定,第一感覺就不會差太多;管理好內(nèi)存,基本管理好了一半 crash;管理好 UI,等于管理了人機交互感受。

UI 上的開發(fā)是:渲染效率與渲染效果的平衡。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Google
    +關注

    關注

    5

    文章

    1748

    瀏覽量

    57196
  • BUG
    BUG
    +關注

    關注

    0

    文章

    155

    瀏覽量

    15628
收藏 人收藏

    評論

    相關推薦

    需要無刷電控硬件工程師

    需要無刷電控硬件工程師,地點東莞松山湖。最好有5-10經(jīng)驗,大功率電摩電控。有意私聊。
    發(fā)表于 09-11 22:51

    尋求專業(yè)工程師幫助設計USB多口充電器

    嗨, 我正在開發(fā)款USB多口充電器,現(xiàn)尋求一位專業(yè)工程師或產(chǎn)品設計的幫助。希望能夠與有經(jīng)驗
    發(fā)表于 08-05 12:03

    嵌入式軟件工程師如何提升自己?

    ,可以為自己的職業(yè)生涯打下堅實的基礎,并實現(xiàn)個人的職業(yè)目標。愿每一位嵌入式軟件工程師都能在這個充滿挑戰(zhàn)和機遇的領域中取得成功!
    發(fā)表于 06-12 11:20

    名單公布!【書籍評測活動NO.33】做了50軟件開發(fā),總結出60條經(jīng)驗教訓,每條都太扎心!

    寫這本書的目的是不讓你們走我“踩坑”的老路、步我的后塵。 一位經(jīng)驗豐富的軟件工程師在讀了本書的教訓清單后評論說 :“每點都太扎心了,有些還不止扎過我
    發(fā)表于 05-17 14:36

    嵌入式軟件工程師和硬件工程師的區(qū)別?

    嵌入式軟件工程師和硬件工程師的區(qū)別? 嵌入式軟件工程師 嵌入式軟件工程師是軟件開發(fā)領域中的種專
    發(fā)表于 05-16 11:00

    為何國外工程師偏愛使用for(;;)來實現(xiàn)MCU死循環(huán)?

    一位工程師發(fā)現(xiàn),國外工程師在給demo在做死循環(huán)時用的是for(;;),而不是常用的while(1)。這僅僅是個人習慣的問題,還是有更深層次的含義?
    發(fā)表于 04-01 11:26 ?426次閱讀
    為何國外<b class='flag-5'>工程師</b>偏愛使用for(;;)來實現(xiàn)MCU死循環(huán)?

    一位硬件工程師的歷練之路:從入門學習理論到... #搞笑 #硬件工程師 #電子工程師 #揚興科技

    硬件工程師揚興科技
    揚興科技
    發(fā)布于 :2024年03月13日 17:50:21

    【2023電子工程師大會】我和LabVIEW:工程師經(jīng)驗分享pp

    【2023電子工程師大會】我和LabVIEW:工程師經(jīng)驗分享ppt
    發(fā)表于 01-03 16:31 ?13次下載

    智能手機飛速發(fā)展的十年回顧總結

    又到了每年年底寫總結報告的時候了,讓我們起回顧下智能手機飛速發(fā)展的十年。
    的頭像 發(fā)表于 12-05 10:56 ?1612次閱讀
    智能手機飛速發(fā)展的<b class='flag-5'>十年</b>回顧<b class='flag-5'>總結</b>

    【熱招】蘇州,單片機工程師

    【單片機工程師】 3及以上經(jīng)驗,要求有智能產(chǎn)品經(jīng)驗。 崗位職責: 1、根據(jù)MRD,與產(chǎn)品部等部門的需求,負責對新開發(fā)的產(chǎn)品進行可行性分析,
    發(fā)表于 11-28 14:02

    中高級【嵌入式驅(qū)動工程師】年薪50w內(nèi)可談

    中高級【嵌入式驅(qū)動工程師】 年薪50w以內(nèi)可談 工作?地點:北京市 了解更多 ?5以上內(nèi)核驅(qū)動開發(fā)經(jīng)驗 ??需要有國產(chǎn)化操作系統(tǒng)/芯片平臺的驅(qū)動
    發(fā)表于 11-23 13:35

    經(jīng)典設計經(jīng)驗筆記,電子工程師必備基礎知識

    電子發(fā)燒友網(wǎng)站提供《經(jīng)典設計經(jīng)驗筆記,電子工程師必備基礎知識.pdf》資料免費下載
    發(fā)表于 11-21 11:13 ?12次下載
    經(jīng)典設計<b class='flag-5'>經(jīng)驗</b>筆記,電子<b class='flag-5'>工程師</b>必備基礎知識

    FPGA工程師需要具備哪些技能?

    、設計思路 FPGA芯片是開發(fā)高速數(shù)字電路設計的理想解決方案之。FPGA芯片基于HDL的設計方法允許工程師使用高級語言進行設計。因此,F(xiàn)PGA工程師需要具備設計思路能力,包括分析需
    發(fā)表于 11-09 11:03

    工程師筆記——MM32F0040使用總結

    工程師筆記——MM32F0040使用總結
    的頭像 發(fā)表于 10-26 18:09 ?432次閱讀
    <b class='flag-5'>工程師</b>筆記——MM32F0040使用<b class='flag-5'>總結</b>

    挑戰(zhàn)吧,HarmonyOS應用開發(fā)工程師

    一年一度屬于工程師的專屬節(jié)日1024,多重活動亮相啦~ 參與活動即有機會獲得HUAWEI Freebuds 5i 耳機等精美禮品!
    發(fā)表于 10-25 15:51