『壹』 作為軟體工程師應該具備哪些基本素質
1:團隊精神和協作能力
把它作為基本素質,並不是不重要,恰恰相反,這是程序員應該具備的最基本的,也是最重要的安身立命之本。把高水平程序員說成獨行俠的都是在囈語,任何個人的力量都是有限的,即便如linus這樣的天才,也需要通過組成強大的團隊來創造奇跡,那些遍布全球的為linux寫核心的高手們,沒有協作精神是不可想像的。獨行俠可以作一些賺錢的小軟體發點小財,但是一旦進入一些大系統的研發團隊,進入商業化和產品化的開發任務,缺乏這種素質的人就完全不合格了。
2:文檔習慣
說高水平程序員從來不寫文檔的肯定是乳臭未乾的毛孩子,良好的文檔是正規研發流程中非常重要的環節,作為代碼程序員,30%的工作時間寫技術文檔是很正常的,而作為高級程序員和系統分析員,這個比例還要高很多。缺乏文檔,一個軟體系統就缺乏生命力,在未來的查錯,升級以及模塊的復用時就都會遇到極大的麻煩。
3:規范化,標准化的代碼編寫習慣
作為一些外國知名軟體公司的規矩,代碼的變數命名,代碼內注釋格式,甚至嵌套中行縮進的長度和函數間的空行數字都有明確規定,良好的編寫習慣,不但有助於代碼的移植和糾錯,也有助於不同技術人員之間的協作。
fans叫囂高水平程序員寫的代碼旁人從來看不懂,這種叫囂只能證明他們自己壓根不配自稱程序員。代碼具有良好的可讀性,是程序員基本的素質需求。再看看整個linux的搭建,沒有規范化和標准化的代碼習慣,全球的研發協作是絕對不可想像的。
4:需求理解能力
程序員需要理解一個模塊的需求,很多小朋友寫程序往往只關注一個功能需求,他們把性能指標全部歸結到硬體,操作系統和開發環境上,而忽視了本身代碼的性能考慮,有人曾經放言說寫一個廣 告交換程序很簡單,這種人從來不知道在百萬甚至千萬數量級的訪問情況下的性能指標是如何實現的,對於這樣的程 序員,你給他深藍那套系統,他也做不出太極鏈的並訪能力。
性能需求指標中,穩定性,並訪支撐能力以及安全性都很重要,作為程序員需要評估該模塊在系統運營中所處的環境,將要受到的負荷壓力以及各種潛在的危險和惡意攻擊的可能性。就這一點,一個成熟的程序員至少需要2到3年的項目研發和跟蹤經驗才有可能有心得。
5:復用性,模塊化思維能力
經常可以聽到一些程序員有這樣的抱怨,寫了幾年程序,變成了熟練工,每天都是重復寫一些沒有任何新意的代碼,這其實是中國軟體人才最大浪費的地方,一些重復性工作變成了熟練程序員的主要工作,而這些,其實是完全可以避免的。
復用性設計,模塊化思維就是要程序員在完成任何一個功能模塊或函數的時候,要多想一些,不要局限在完成當前任務的簡單思路上,想想看該模塊是否可以脫離這個系統存在,是否可以通過簡單的修改參數的方式在其他系統和應用環境下直接引用,這樣就能極大避免重復性的開發工作,如果一個軟體研發單位和工作組能夠在每一次研發過程中都考慮到這些問題,那麼程序員就不會在重復性的工作中耽誤太多時間,就會有更多時間和精力投入到創新的代碼工作中去。
一些好的程序模塊代碼,即便是70年代寫成的,拿到現在放到一些系統裡面作為功能模塊都能適合的很好,而現在我看到的是,很多小公司軟體一升級或改進就動輒全部代碼重寫,大部分重復性工作無謂的浪費了時間和精力。
6:測試習慣
作為一些商業化正規化的開發而言,專職的測試工程師是不可少的,但是並不是說有了專職的測試工程師程序員就可以不進行自測;軟體研發作為一項工程而言,一個很重要的特點就是問題發現的越早,解決的代價就越低,程序員在每段代碼,每個子模塊完成後進行認真的測試,就可以盡量將一些潛在的問題最早的發現和解決,這樣對整體系統建設的效率和可靠性就有了最大的保證。
測試工作實際上需要考慮兩方面,一方面是正常調用的測試,也就是看程序是否能在正常調用下完成基本功能,這是最基本的測試職責,可惜在很多公司這成了唯一的測試任務,實際上還差的遠那;第二方面就是異常調用的測試,比如高壓力負荷下的穩定性測試,用戶潛在的異常輸入情況下的測試,整體系統局部故障情況下該模塊受影響狀況的測試,頻發的異常請求阻塞資源時的模塊穩定測試等等。
當然並不是程序員要對自己的每段代碼都需要進行這種完整測試,但是程序員必須清醒認識自己的代碼任務在整體項目中的地位和各種性能需求,有針對性的進行相關測試並盡早發現和解決問題,當然這需要上面提到需求理解能力。
7:學習和總結的能力
程序員是人才很容易被淘汰,很容易落伍的職業,因為一種技術可能僅僅在三兩年內具有領先性,程序員如果想安身立命,就必須不斷跟進新的技術,學習新的技能。善於學習,對於任何職業而言,都是前進所必需的動力,對於程序員,這種要求就更加高了。
但是學習也要找對目標,一些小coding有些codingTO就是這樣的coding上只是一些Cfans們,他們也津津樂道於他們的學習能力,一會學會了asp,一會兒學會了php,一會兒學會了jsp,他們把這個作為炫耀的資本,盲目的追逐一些膚淺的,表面的東西和名詞,做網路程序不懂通訊傳輸協議,做應用程序不懂中斷向量處理,這樣的技術人員,不管掌握了多少所謂的新語言,永遠不會有質的提高。
善於總結,也是學習能力的一種體現,每次完成一個研發任務,完成一段代碼,都應當有目的的跟蹤該程序的應用狀況和用戶反饋,隨時總結,找到自己的不足,這樣逐步提高,一個程序員才可能成長起來。一個不具備成長性的程序員,即便眼前看是個高手,建議也不要選用,因為他落伍的時候馬上就到了。
具備以上全部素質的人,應當說是夠格的程序員了,請注意以上的各種素質都不是由IQ決定的,也不是大學某些課本里可以學習到的,需要的僅僅是程序員對自己工作的認識,是一種意識上的問題。那麼作為高級程序員,以至於系統分析員,也就是對於一個程序項目的設計者而言。
『貳』 程序員的 職業素養
說起職業素養,可能大家腦子里馬上反映出來的是西服領帶公文包的精幹白領形象,其實作為程序員來說,外在可能沒有那麼重要,更多的是內在職業素養,本期調查分享了兩個研發小組的故事,讓大家在統計數據的基礎上進一步了解——什麼是程序員需要的職業素養?案例一:問題團隊AD公司是個在發展壯大中的貿易公司,由於業務發展員工從剛開始的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%的程序員認為編碼規范和文檔規范是程序員的必備職業素養之一。
『叄』 作為一名優秀的程序員,要具備哪些基本功
程序員(英文Programmer)是從事程序開發、維護的專業人員。
作一個真正合格的程序員,需要具備:
1:團隊精神和協作能力
團隊精神和協作能力是作為一個程序員應具備的最基本的素質。
2:文檔習慣
文檔是一個軟體系統的生命力。作為代碼程序員,必須將30%的工作時間寫用於技術文檔。沒有文檔的程序員勢必會被淘汰。
3:規范化的代碼編寫習慣
知名軟體公司的代碼的變數命名、注釋格式,甚至嵌套中行縮進的長度和函數間的空行數字都有明確規定,良好的編寫習慣,不但有助於代碼的移植和糾錯,也有助於不同技術人員之間的協作。
4:需求理解能力
程序員要能正確理解任務單中描述的需求。
5:模塊化思維能力
作為一個優秀的程序員,其思想不能在局限當前的工作任務裡面,要想想看自己寫的模塊是否可以脫離當前系統存在,通過簡單的封裝在其他系統中或其他模塊中直接使用。
6:測試習慣
測試是軟體工程質量保證的重要環節,但是測試不僅僅是測試工程師的工作,而是每個程序員的一種基本職責。程序員要認識測試不僅是正常的程序調試,而要是要進行有目的有針對性的異常調用測試,這一點要結合需求理解能力。
7:學習和總結的能力
程序員是很容易被淘汰的職業,所以要善於學習總結。