程序員六大職業素養

提及職業素養,可能你們腦子裏立刻反映出來的是西服領帶公文包的精幹白領形象,其實做爲程序員來講,外在可能沒有那麼重要,更多的是內在職業素養,本期調查分享了兩個研發小組的故事,讓你們在統計數據的基礎上進一步瞭解——什麼是程序員須要的職業素養?程序員

案例一:問題團隊A安全

    D公司是個在發展壯大中的貿易公司,因爲業務發展員工從剛開始的10人兩年內增長到150多人,管理上出現了溝通效率低、對員工工做難以監控的現象。公司 想近期上OA系統,以增強公司的工做效率、支持快速增加的業務。通過幾回與F開發公司的溝通後,雙方肯定了合做意向。安排有兩年開發經驗的開發工程師蘇 成,做爲項目經理帶領三個開發人員,開始了D公司的OA項目。架構

    因項目不大,沒有特別安排需求工程師,而由項目經理與客戶確認需求後進行開發,初爲項目經理的蘇成信心爆棚:對外,他想固然地按照合同後附的簡單需求說明 草率開發;對內,他認爲項目經理擁有絕對權力,任何關於開發的不一樣意見都聽不進去。在第一期快結束時,蘇成已與項目組成員發生了N次爭吵,你們紛紛要求調 離項目組,團隊面臨崩潰。框架

    在兩個月未與客戶溝通的狀態下,蘇成項目組向D提供了OA系統一期產品,按合同規定包括了:員工管理一項功能和其中四個子項。看完基本功能演示後,D公司 的HR經理Helen幾乎崩潰——OA系統中員工管理沒與考勤部分聯繫起來,並且在系統中增長一個新用戶須要五步,十分繁瑣,不少功能也與公司需求相差極 大。學習

    可是蘇成卻認爲這些都是小問題,更讓Helen氣結的是要求增長一個小的統計功能時,他竟然說作不了。後來才瞭解到,原來在開發時,項目組並無留下文 檔,加之團隊其它幾個成員均已準備離開項目組,任何在此模塊中的小小變化都會面臨全部代碼從新開發的局面,更不用說要新增什麼功能了。測試

    最終蘇成辛苦開發了幾個月卻沒有獲得相應地回報,客戶不滿意,項目組成員不滿意,研發部總監更是對他的能力產生了懷疑,在幾經努力拿到D公司的第二期項目開發合同以後,更換了項目經理。編碼

點評:程序員如何以明確需求爲基礎與客戶溝通?加密

    若是有專門掌握需求編寫技術和經驗的需求工程師做爲客戶和程序員之間的橋樑是最理想的狀態。但以國內目前的國情,每一個項目組都配有需求工程師的並很少。因 此,正確地幫客戶表達需求、正確地理解需求就成了程序員的基本素質之一。在這次調查中66.67%的被訪者認爲「能幫助客戶正確提出需求」是程序員職業素 養之一,可見在程序員內部已就此達成了至關的共識。認爲「能使客戶需求更完善」是程序員看重的職業素養之一,佔到這次調查的55.13%,這說明超過一半 的程序員認識到,幫助客戶完善需求會節省雙方的時間和精力。對象

那麼如何才能提升本身的需求分析能力呢?如下分享幾個有關需求的小技巧:項目管理

1.儘可能提升本身的表達和溝通能力。良好的表達和溝通能力能在客戶不能清楚表達需求時,融入到客戶組織內部,瞭解客戶的工做流程,與客戶共同更好地、更準 確地定義和分析需求。這次調查中60.90%的被訪者認爲溝通能力是程序員應具有的基本能力,但只有28.85%的程序員認爲「表達能力」是程序員必備的 基本能力。溝通當然很重要,但咱們更應該進一步認識到準確表達本身的觀點和意見也是成功溝通的基礎之一。若是隻「溝」而不「通」仍然是在浪費方面寶貴的時 間。

2.應用多種方式瞭解需求。經常使用的方法有:問題分析法和建模分析法以及幾種方法的結合。好比在問題分析法中應用面向對象的思想,與客戶的員工談話,訪談首先要面向工做流程,面向任務,面向角色,也就是用面向對象的思想幫助客戶理清思路。

3.不臆測需求。若是有專門的需求工程師,有一點要特別強調,就是在編碼過程當中當需求不明確時,必須與項目經理或需求工程師及時溝通,程序員不能自做主張地猜想客戶的需求。

4.不過分承諾。不少銷售人員拿到項目,向客戶大包大攬,甚至徹底不顧公司的現有開發能力向客戶承諾不少功能。在定義需求階段,必定要向客戶說明「什麼是 咱們能作的,什麼是咱們應該作的,什麼是咱們不能作的」。不少時候過分承諾致使了新功能沒法實現的同時,原有功能也受到影響。在這次調查中,有 59.62%(近六成)的被訪者正確地認識到對客戶提出的不合理需求拒絕得當也是程序員職業素養的一個重要方面,這是很是可貴的。

案例二:嚴格開發流程的團隊B

    國資委某下屬集團公司要上OA系統,C公司在研發能力、價格兩個方面以綜合分第一的成績競標成功。擁有10年項目管理經驗的李石被任命爲項目經理,並由他組建團隊。李石對團隊成員只有三個要求:分析能力、產品意識、較強的團隊意識。

 

初選方案

    需求肯定後,項目有兩個方案:更流行的BS模式和傳統的CS模式。李石安排兩個程序員前期負責選方案,分別基於兩種模式開發用戶權限管理系統的原型,給你們作演示,並結合客戶特別評估每個架構的優劣。

分析了BS/CS的特色、結合客戶的需求,他們發現:

1.從流程的定製來看CS結構更加利於客戶方便地進行「可視化」定製;

2.從公文的「不可修改、保密性」以及電子圖章的「不可詆譭性」需求來看,CS框架更加利於實現DRM技術和數字指紋技術實現;

3.從公文的打印需求與通常WEB報表的差別性來看,CS框架更加適合對打印格式的定製與控制;

4.從客戶提出的內部電子會議的實時性來看,CS框架明顯優於BS框架的非狀態性,可以作到更順暢、更及時的溝通;

5.從系統的安全性來說,CS框架更加適合硬加密系統(如加密狗、U盤Key)與系統的對接。

 

產品開發

    在開發過程當中李石強調了每一個程序員的產品意識,取得了不錯的效果。好比客戶要求一個能上傳文件的功能時,並無提出UI需求,團隊的B程序員並無簡單完成任務了事,而是作出一次能同時選取上傳5個文件的程序。這種產品意識爲客戶使用帶來方便,彌補了需求的不足。

 

團隊配合

    在團隊B中,每一個程序員都作到了作完一個功能後與項目經理溝通進度、結果,並與負責測試的同事溝通,及時檢測Bug,及時修改並及時迴歸。每一個功能的實現都相對完善。及時的溝通與相互學習,還促進了團隊磨合。

    通過8個月的開發,OA項目第一期完成基本功能順利上線。C公司已順利拿到了客戶第二期的開發合同。

 

點評:成功的開發須要這樣的程序員

經過上面的案例,咱們爲程序員總結出以下素養:

1.學習和分析能力。每一個團隊都在成長,做爲程序員這個羣體就更須要「與時俱進」。尤爲是在開發這個知識突飛猛進的行業裏。同時分析能力也是必不要少的。 在調查中71.15%的程序員認爲,學習能力很是重要,同時有57.69%的程序員認爲,在技術方面有不一樣的意見時,處理穩當是程序員應該具備的職業素 養。相信這個案例爲咱們提供了新的思路。

2.與內外保持良好的溝通,永遠是成功的保證。及時彙報、溝通進展也能夠在第一時間發現本身的誤差。數據證實59.62%的程序員認爲「彙報項目進展時明確及時」是重要的職業素養。

3.產品意識。良好的產品意識能夠大幅度提升開發效率,也能有效的彌補需求不足。例如,在案例二中,在作文件上傳功能時,充分考慮了客戶使用的方便性,彌補了需求中被忽略的細節。

4.團隊意識。強烈的團隊意識能幫助本身和整個團隊更快成長,由於知識的分享是知識學習中一個最有效的方法,尤爲是在程序員這個行當裏。

5.編碼規範和文檔規範。據調查顯示有分別由80.77%和68.59%的程序員認爲編碼規範和文檔規範是程序員的必備職業素養之一。
相關文章
相關標籤/搜索