程序開發人員缺乏經驗的 7 種表現

作者 | Lokajit Tikayatray

譯者 | 王莉敏

策劃 | 李俊辰

知道這些表現,你才能在自己的程序員職業生涯中不犯相同的錯誤。

軟件行業的工作經驗和你從事這個行業的工作年限直接相關。這句話在某種程度上是對的,但是你從事這項工作的年限,並不一定代表你獲得了相同年限的工作經驗,正如一句話所說:“我們以爲我們是工作了十年,其實卻只有一年的工作經驗,只不過又重複用了九年”。

有一些人雖然工作了很多年,但工作表現就像剛入行的新人。他們幾乎不學習軟件開發的基礎知識 。除了最初幾年有所成長,後期一直停滯不前,而且他們不明白爲什麼。

根據開發人員的某些習慣,可以非常明顯地分辨出誰更專業,誰更業餘。讓我們深入剖析下業餘程序開發人員的 7 種表現,每個程序開發人員都應該引以爲戒,這些錯誤會阻礙我們的職業發展。

  1. 一次性提交大量代碼

回憶下,你是否碰到過一次性提交大量代碼的人,你都不想給他做代碼評審。是的,不專業的開發人員就會這樣做。他們會在一次代碼評審請求中包含多個模塊的修改,而且會催促你優先評審他們的代碼。是啊,能不急嗎,排到後邊,還需要解決代碼衝突的問題。這個問題在很多高級開發工程師中也存在,他們在功能開發期間不做任何提交,只有在功能徹底完工後,纔會提交所有修改,於是代碼評審中的任何意見都會引起大量的修改。

當我碰到這種代碼評審請求時,我首先做的是要求提交者按功能模塊將其拆分成多個小的請求。我只會對 issues(任務管理系統)中的第一個功能需求評審,然後將其轉回提交者。如果我有時間,我會和提交者連線進行代碼實時評審。

你能做什麼:

  1. 代碼寫的很爛

缺乏經驗的開發人員寫不出漂亮的代碼,他們寫出的代碼會很混亂,而且分佈在代碼庫的各個部分。

當你嘗試閱讀這類代碼時,會感覺自己身處一座迷宮之中。你會逐漸忘記自己是從什麼地方開始的,要尋找什麼以及這段代碼完成了什麼功能。

有經驗的開發人員知道代碼如何設計。除非要開發的功能顯而易見,首先需要在紙上寫出你對需求的理解並畫出流程圖(簡化版的規格需求說明書),在腦海裏對這段代碼進行一個完整的構思。除非你徹底弄清楚瞭如何修改,否則不要開始代碼編寫。

如果你不遵守以上的規則,當你回顧自己完成的代碼時會非常痛苦。以後如果需要修正問題或者增加功能,也會變得非常棘手。

你能做什麼:

  1. 同時開展多項工作

缺乏經驗的開發人員不知道什麼時候開始一項任務、如何推進、什麼時候結束。他們試圖並行處理多項任務。他們不知道如何將一項大任務分解爲小的模塊,從而減輕實現的難度。

當他們收到一項任務時,並不是第一時間和上級確認需求,而是立刻就開始編程,而且在做任務期間,也不會和上級就任務進度進行溝通。只有當任務完成時,他們纔會向你反饋。到那個時候,你只能祈禱他們完成的功能就是你想要的。

缺乏經驗的開發人員的另一個表現是同時推進多項任務,他們會同時處理多項事情,如:實現多個沒有太大聯繫的功能點、解決生產環境問題、協助其他同事工作等。

最終,從他們那裏得不到有效的產出。雖然他們的態度和出發點是好的,但對整個團隊造成的後果是災難性的,浪費了很多的時間,導致團隊得日夜趕工。

你能做什麼:

  1. 性格傲慢

對於缺乏經驗的開發人員,傲慢是非常致命的。傲慢會導致他們不能接受別人的批評和建議。當你對他們的代碼或者陳述給出意見時,他們會認爲你是在質疑他們的能力。

許多新人由於無知,都會表現出這種傲慢。剛走出校門的他們充滿自信,並沒有意識到他們在學校學到的東西離社會要求還有很大差距。這些人中的聰明者會很快調整自己,以歸零的心態,努力學習並適應公司文化。

其實不只是新人——一些有幾年工作經驗的開發人員也會表現出這種傲慢,一部分原因是其滿足於個人獲得的專業成就,另一部分可能的原因是其缺乏和優秀的人共事的機會,有點坐井觀天。

此外,傲慢的行爲也從另一方面證明這樣的開發人員確實缺乏經驗。這樣的行爲會對他們的職業發展造成很多阻礙,因爲沒有人喜歡和一個傲慢的人共事。當成長變慢時,他們不會從自身找原因,而是更多的歸罪於別人。

你能做什麼:

  1. 不能從之前的錯誤中學到經驗

我一直認爲,對於軟件開發人員,反饋機制是一個很有效的工具。來自他人的反饋,會讓我們明白自己的短板是什麼以及如何去改進。一個聰明的開發人員明白如何藉助他人反饋來促進自己的成長。

根據一個開發人員對建設性意見的反應,你可以判斷出他是否缺乏經驗。缺乏經驗的開發人員不接受任何建設性的建議,甚至代碼評審中的評論,他都會認爲是對他個人的一種攻擊。

很多年前,我有一個同事給我寫了很長的一封郵件,教我如何來評審代碼,他對我給他代碼的評論感到憤怒。他的主要觀點是我不應該關注編碼標準,因爲他知道如何編碼,我應該只關注代碼能否滿足功能需求。

如果一個開發人員因爲別人對他代碼給出的評論,而感覺被冒犯,只能表明他不具有真正的開發經驗。他抱着做一天和尚撞一天鐘的態度工作,卻感慨沒有遇到賞識自己的伯樂。

你能做什麼:

  1. 工作時間處理私人事務

日常工作中,總是發現團隊裏的一些成員在工作時間處理私人事務,如:看社交媒體,瀏覽購物網站,玩遊戲。

我之前還有個團隊成員,上班時間炒股。因爲他需要不時地關注股票的 K 線走勢,造成個人的產出質量不高。其他同事對他很有意見,因爲他們需要花費更多的時間去趕工期。

當開發經理和這個開發人員談話之後,他改變了一段時間,但是很快就故態復萌。最終,公司只能把他開除了。

工作時間處理私人事務,這是違反商業道德,並且表現了你的不專業。我們需要對工作敬業,畢竟我們要靠它謀生。

你能做什麼:

  1. 盲目追逐技術潮流

開發人員缺乏經驗的另一個表現是面對技術潮流的態度。你會發現他們總是在談論技術潮流,當有一個新的潮流出現時,他們會立刻丟棄原來的潮流,投入新的懷抱。

缺乏經驗的開發人員總是在學習教程。毫無疑問,教程是很有用的學習工具,但是,不進行任何實踐而只是按照教程一步步操作無疑是浪費時間。它會讓你虛幻地覺得自己好像都掌握了,但是知識是否掌握了,需要通過真實的項目進行檢驗。

開發人員很少會用熱門技術或者從教程中學到的知識來實現新的東西,他們學習熱門技術或者教程很多是爲了滿足自己的虛榮心,或者擔心自己會錯過什麼。

你能做什麼:

    總結    

缺乏經驗的開發人員會因爲自己的效率低下進而降低整個團隊的效率。他對待自己工作的錯誤態度,會讓其在職業發展中錯失很多機會。

瞭解並避免這種錯誤的態度和工作方式,是聰明人的做法。如果你不幸染上了這些壞習慣,隨着時間的推移,你會越來越難以擺脫。

謝謝你閱讀這篇文章。希望你能避開這些陷阱,早日獲得職業上的成功。

 延伸閱讀

https://levelup.gitconnected.com/top-7-signs-of-an-inexperienced-programmer-5fc3f04658f3?fileGuid=rrJJ3dW9GdcPCVXp

本文由 Readfog 進行 AMP 轉碼,版權歸原作者所有。
來源https://mp.weixin.qq.com/s/RMImzGZO8X1GSmlc4o69TQ