天天看點

良好習慣成就Better程式員

良好習慣成就Better程式員

  

慎于說Yes

在沒有搞清楚開發需求、任務工作量、團隊期望值之前,有前途的程式員不會輕易答應。特别是對于新人來說,比較急于表現自己,對于同僚或者老闆的工作安排來者不拒,精神可嘉,方法不可取。承諾太多,會出現自己無法按時完成的情況,即使按時完成,也可能沒有達到别人的期望值,長期以往别人對你的失望會越來越多。

敢于說No

看起來和第一條雷同,其實細究起來不一樣。第二條執行起來比第一條難得多。當遇到明顯不合理的要求時,可以考慮拒絕,前提是準備好了全面充分的理由。不要經常說No,但是一旦說了,就要切中要害。有前途的程式員不會悶頭幹活,知道自己的定位和團隊期望,厘清楚哪些是不合理的要求,哪些是合理的要求,然後把明顯不合理的要求和上司溝通下,取得支援。

建構自己的知識體系

在資訊爆炸的年代,碎片化的知識很多,系統學習的時間越來越少,如果沒有自己的知識體系,很容易被淹沒在知識的海洋中,而且難以記憶。100分程式員推薦的做法,通過Wiki或者其他知識管理工具建構一個知識架構,大的分類可以包括軟技能、架構、語言、前端、後端等,小的分類可以更細化。

培養大局觀

程式員比較容易陷入的困境是專注于自己的一畝三分地,不關心團隊的進度和業績,也不關心軟體的整體架構和其他子產品。這種狀态長期下去沒有好處,特别是在大公司中,逐漸成長為一顆螺絲釘。100分程式員會在工作之餘,多看看其他在做什麼,看看團隊的整體規劃,看看軟體系統的架構和說明文檔。對自己的工作更了解,而且知道為什麼這個産品應該這樣設計,為什麼上司應該這樣做規劃,這種大局觀非常有利于自己的職業生涯。

代碼規範

程式員在新手時期需要培養良好的代碼規範。最直接的辦法,遵循公司已有的代碼規範(如果沒有類似的規定,也是醉了),從簡單的變量命名到子產品劃分,有些規則可以導入到編碼工具中,更多的部分需要自己體會和遵守。關于此方面的知識,最權威的書籍是《代碼大全》,别誤會,書名是個美麗的錯誤,裡面不是代碼集錦。對于新手來說,養成一個統一的編碼風格非常重要,是基礎一步。

代碼審查

把這個單獨拎出來說,是因為對于程式員來說很重要。很多快速成長的公司沒有這個步驟,建議大家能夠堅持下來。讓别人審查自己的代碼,可以得到更多的回報,也是和同僚交流的好機會;審查别人的代碼,可以借鑒别人的經驗和思路。通常情況下,代碼審查比自己寫代碼的收獲更大,對于新手來說更有價值。隻要你想做,不論形式是不是正規,都可以執行下去,最好形成團隊的習慣。

一個時間段内隻專注于一種類型的語言

如果你正在設計或開發網站,你将需要同時熟悉多種不同的語言。你可能會想同時學習所有的這些語言,特别是考慮到它們是如何互相關聯的。

我想,在某種程度上,這是不可避免的。但如果你真的想快速提高,我建議你專注于一個特定領域的專業知識。你想更好地利用CSS?把你的重點放在這一點。嘗試使用一個單一的HTML文檔隻使用CSS實作不同的布局。 CSS Zen Garden 是一個使用相同布局實作不同頁面樣式非常棒的例子。你也可以通過查找元素的清單,并把精力集中在裡面。舉個例子來說,你熟悉CSS2,但想提升對 CSS3 的了解,你可以學習CSS3屬性并逐一的實作它們。你可以閱讀目前的 CSS3規範 ,還可以通過每個子產品的學習來了解它在浏覽器上能(或不能)做什麼。

通過注釋來寫邏輯

說到編碼,我有堅持很多原則和想法。其中一個就是,代碼中95%都是邏輯。另一個就是從人類語言到程式設計語言,邏輯并沒有改變。

這也就是意味着,如果你能在代碼中寫出來,也就可以用英語或者其他語言寫下來。

良好的時間管理

遲到對于任何一家公司都是個頭痛的問題。作為一個程式員,有時候為了完成任務常常不得不熬夜,進而導緻第二天上班就遲到了。但是我們忽略了這一點,我們的工作時間至關重要,因為在這段時間裡我們要和客戶同步,也要與團隊其他成員一齊協作。

深入了解客戶需求

僅僅了解單一使用者的表面意思是遠遠不夠的。一個偉大的程式員應該具備能把繁瑣的要求了解并分解成項目的技術任務或子任務的能力,并且最後拿到的成果應精确滿足客戶的需求。

絞盡腦汁還是“NO”

假如抓耳撓腮還是找不出解決辦法,我們該如何是好?一個偉大的程式員應該足智多謀,能靈活應對困境。他們會去詢問同僚,或者是向團隊上司者請教;在網際網路上面搜尋,然後耐下心來一遍又一遍地試驗。相信山窮水盡疑無路,柳暗花明又一村,投降兩個字從未出現在他們的字典上。

程式設計之前準備好全套算法

親~還記得我們老師逼我們畫的流程圖嗎?還記得一個個案例和僞代碼嗎?他們都是灰常重要的軟體開發手段。一個偉大的程式員如果木有事先準備好算法,那他會不會像個傻小子似的隻顧寫代碼呢?是以,在開工之前,做好全套的算法是必須的。

了解and幫助定義驗收标準

是否需要高成次測試腳本是産品所有者決定的,但是,作為一個偉大的程式員必須能夠編寫技術測試腳本,并且也要認識到如果跳過了這一步驟可能會帶來的後果。

主動一點點