- 還沒升級成響應式網頁設計? 01-01
- 助力清華同方新媒體—記8月31日鋒云科技成功中標清華同方官網響應式網站升級項目! 01-01
- 為什么有的網站建設的“很爛” 卻能排在首頁? 01-01
- 企業網站建設如何突出網站價值 01-01
許多人都有個共同特點,只有當他需要幫助的時候,他才會求助于論壇或者群。優秀程序員不同之處在于他們會經常瀏覽論壇去幫助他人。相比較于靠別人幫助解決問題,他們幫助他人讓自己學到更多。在一個團隊中也是一樣,幫助他人解決問題收獲更多。相信我,了解他人的問題,思考并最終提供解決方案吧,你會比之前學到的更多。
3. 寫簡單易懂,有邏輯性的代碼
正如KISS原則(保持短小精悍)適用于生活的方方面面一樣,它也適用于編程。盡量寫有邏輯的代碼,避免復雜化。有時人們寫復雜的代碼僅僅是為了展示他們有能力寫出這樣的代碼。我的經驗告訴我,簡單而富有邏輯的代碼非常的好,會產生的問題更少,也更容易擴展。我記得一句話:
好的代碼本身就是最好的文檔。當你想要加注釋的時候,問問你自己,“我能如何改進我的代碼,才能不寫注釋也讀得懂呢?”
4. 花更多的時候分析問題,你將會花更少時間去解決問題
花更多的時間理解和分析問題,然后再設計方案吧。你會發現剩下的事情很容易了。設計不是說要用建模語言和工具,可以是僅僅看看天空在腦子里構思。那些在遇到問題就開始敲代碼的人往往會最終偏離需求。
如果你洗澡的時候不能理清整個程序的結構,那么你還沒準備好開始編程。 – Richard Pattis
5. 成為第一個檢查你的代碼的人
雖然有一點點難,但試著在其他人修改你代碼之前修改它,隨著時間的推移,你會寫出幾乎沒有bug的代碼。對你的代碼做沒有任何偏見的檢查,也不要猶豫讓其他人來檢查你的代碼。和其他優秀的程序員一起工作,接受他們的意見能夠幫助你也成長為一個優秀的程序員。
6. 不要迷失在快速更迭的科技世界
在IT行業中,我經常遇見許多人,他們對現在的工作不滿,甚至離開它去追尋新的工作,理由是因為他們想要學習最新的科技。我們每天聽到的都是新工具、接口、框架,能讓程序更簡單,速度更快。這在科技世界中司空見慣并會一直如此。但是最基本的最核心的科技變化比那些框架、工具和接口的變化小得多。就像大海,大海表面上波濤翻滾,但大海深處卻相當平靜,而那里才是水生生物生存的地方。所以將你自己置身于核心技術的大海深處吧。舉個例子,在Java企業級應用中,每個星期都會出現新的框架,但是核心的技術是不變的,譬如基于客戶端-服務器端的請求,MVS模式,filters/servlets/JSP,數據源綁定,XML解析等等。所以要花功夫去學習核心概念,而不是去擔憂日新月異的框架和工具的出現。相信我,有了核心技術的基礎,你會發現學習新的框架,工具以及接口變得更容易了。
7. 應急方案不會持續很長時間
很多時候軟件師們會采用應急方案(可能是時間不夠,可能是問題理解不透徹或者是缺少經驗)。但是這樣往往帶來的結果是,代碼混亂,缺乏可擴展性和維護性,后來浪費了更多的時間。請在你清楚整個方案后再開始實施。我知道有些情況下應急方案無可避免,就好像,一個人應該說實話,但是你在某些情況下不得不說謊。
8. 閱讀文檔
閱讀很多文檔是作為優秀程序員的必備習慣之一。可能是產品說明書、JSR、API文檔、教程等。閱讀文檔幫助你獲得必要的基礎知識,寫出更好的代碼。
9. 你可以學習他人的代碼
我接觸過一些優秀的程序員,他們在IDE里面一直放著JAVA源代碼,并經常在日常工作中閱讀和查閱。他們這樣做不僅是滿足求知的渴望,還從中學習了如何寫優秀的程序。閱讀和查閱那些你認為可靠的出名的開源代碼或者比你資深的程序員的代碼,你會寫出更棒的程序。(擴展閱讀:《閱讀優秀代碼是提高開發人員修為的一種捷徑》)
最后,我想說的但沒有將其列在上面的:不要和他人比較
和他人的比較往往會造成消極的情緒和不健康的競爭。每個人都有他的長處和短處。揚長避短很重要。我也經常看到一些基礎很厲害的程序員范很低級的錯誤。所以僅僅和自己比較,列舉你自己需要改進的地方,并持續改進它。編程是很有意思的事情,享受它吧。
任何一個傻瓜都能寫出計算機能理解的程序,而優秀的程序員卻能寫出別人能讀得懂的程序。
優秀的程序員是在穿過一條單行道的時候還會往兩邊看的人。