對(duì)于剛開始學(xué)習(xí)軟件開發(fā)的新人來說,“必備技能”往往意味著一個(gè)長(zhǎng)長(zhǎng)的、標(biāo)有重要度的學(xué)習(xí)列表,但是過長(zhǎng)的列表通常會(huì)導(dǎo)致新人不知如何開始學(xué)習(xí),壓力倍增。
本文嘗試列舉出最重要的幾個(gè)技能,也期望通過此列表能給新人一個(gè)比較明確的學(xué)習(xí)重點(diǎn)和路徑。
1、深入學(xué)習(xí)一門編程語(yǔ)言
沒有掌握任何一門編程語(yǔ)言,就不可能成為一名編程人員。
許多程序員試圖在學(xué)習(xí)之初一次學(xué)習(xí)幾種編程語(yǔ)言,以便應(yīng)對(duì)他們第一份軟件開發(fā)工作的需要。雖然我認(rèn)為開發(fā)人員最終會(huì)學(xué)習(xí)多種編程語(yǔ)言, 但建議不要在開始時(shí)這樣做。 因?yàn)橥瑫r(shí)學(xué)習(xí)多種語(yǔ)言只會(huì)導(dǎo)致混亂,也會(huì)分散學(xué)習(xí)其它技能的精力。相反,我建議深入的學(xué)習(xí)一種編程語(yǔ)言,這樣也會(huì)對(duì)使用這種語(yǔ)言編寫代碼感到非常有自信。
2、如何組織代碼
新手程序員在完成編程語(yǔ)言的學(xué)習(xí)之后,或者最好在學(xué)習(xí)編程語(yǔ)言的同時(shí),需要掌握的是如何正確的組織代碼。
通過Steven McConnell所著的《Code Complete》,可以幫助學(xué)習(xí)這個(gè)寶貴的技能。
組織代碼意味著編寫良好的、清晰可理解的、不需要大量注釋的代碼,因?yàn)榇a本身是可自注釋的。許多軟件開發(fā)人員究其整個(gè)職業(yè)生涯都不曾具備這樣的技巧,但是這個(gè)技能卻是判斷一個(gè)軟件開發(fā)人員的技術(shù)和能力的首要標(biāo)準(zhǔn)。良好的代碼結(jié)構(gòu)代表的不僅僅是完成了編碼工作,而是對(duì)編碼事業(yè)的熱衷奉獻(xiàn)。
對(duì)于新手程序員來說,簡(jiǎn)潔清晰且含義明確的代碼,能讓你輕松地通過面試。
提升代碼結(jié)構(gòu)已經(jīng)成為了軟件開發(fā)的重要部分,但是提升的過程卻是十分嚴(yán)格的。在這個(gè)過程中,雖然不需要編寫新的代碼,但是卻需要和團(tuán)隊(duì)成員一起花費(fèi)大量時(shí)間來維護(hù)現(xiàn)有的代碼。
3、面向?qū)ο笤O(shè)計(jì)
為了應(yīng)對(duì)軟件開發(fā)中的面向?qū)ο笤O(shè)計(jì)思想,開發(fā)人員也需要學(xué)習(xí)一種面向?qū)ο蟮恼Z(yǔ)言。
面向?qū)ο笤O(shè)計(jì)是一種設(shè)計(jì)復(fù)雜程序的方法,它將代碼分成了單獨(dú)的類和對(duì)象(類的實(shí)例),這些類和對(duì)象封裝了一些特定的功能。
我們一直試圖在軟件開發(fā)中管理復(fù)雜性,用對(duì)象的方式思考就能幫助我們做到這點(diǎn)。面向?qū)ο笤试S我們跳出一堆關(guān)系繁雜的組件,來清晰的定義和設(shè)計(jì)一個(gè)復(fù)雜的系統(tǒng)。
現(xiàn)在已經(jīng)有大量的功能性編程語(yǔ)言,但是在軟件開發(fā)過程中,你會(huì)發(fā)現(xiàn)那些最受歡迎的語(yǔ)言和模型都深受面向?qū)ο笤O(shè)計(jì)的影響。所以就需要深入的理解類、繼承以及如何使用,還有多態(tài)和封裝。
4、數(shù)據(jù)結(jié)構(gòu)和算法
軟件開發(fā)人員應(yīng)該熟悉以下的數(shù)據(jù)結(jié)構(gòu):
? 數(shù)組或向量
? 鏈表
? 堆棧
? 隊(duì)列
? 樹結(jié)構(gòu)
? 哈希
? 集合
掌握并熟練運(yùn)用以上的數(shù)據(jù)結(jié)構(gòu),能幫助開發(fā)人員清晰的定義、存取、管理數(shù)據(jù)。通過合理的數(shù)據(jù)結(jié)構(gòu)和算法,許多困難的編程問題就能迎刃而解。
常見的算法有以下幾種:
? 排序算法
? 查找算法
? 圖搜索算法
? 動(dòng)態(tài)規(guī)劃算法
? 模式匹配算法
善于利用好的算法,能起到事半功倍的效果。如果你對(duì)算法不夠熟悉的話,就很難提出一個(gè)好的解決方案,這也就是需要我們掌握算法的原因。
事實(shí)上,數(shù)據(jù)結(jié)構(gòu)和算法也是軟件開發(fā)中最有趣的領(lǐng)域之一。利用數(shù)據(jù)結(jié)構(gòu)和算法來開發(fā)一個(gè)干凈、簡(jiǎn)潔的解決方案,效果會(huì)非常好。
Gayle Laakmann McDowell的“Cracking the Coding Interview”書中介紹了有關(guān)算法和數(shù)據(jù)結(jié)構(gòu)的所有知識(shí)。
學(xué)習(xí)這些知識(shí)是一個(gè)挑戰(zhàn),但卻是非常值得的。掌握其中的任何一個(gè)技能,都能讓你遠(yuǎn)遠(yuǎn)超過其他人。這些知識(shí)也正是其它軟件開發(fā)人員所不具備的。
5、開發(fā)平臺(tái)及相關(guān)技術(shù)
應(yīng)該至少對(duì)一個(gè)開發(fā)平臺(tái)以及與之相關(guān)的技術(shù)或框架有一定的經(jīng)驗(yàn)。
平臺(tái)通常意味著操作系統(tǒng)(OS),但它也適用于與操作系統(tǒng)類似的其他抽象系統(tǒng)。例如,你可能是專注于Mac或Windows操作系統(tǒng)的Mac開發(fā)人員或Windows開發(fā)人員,同時(shí)你也可以是專注于特定Web平臺(tái)的Web開發(fā)人員。
具備某個(gè)特定平臺(tái)的專業(yè)知識(shí),不僅僅意味著需要熟悉平臺(tái)本身,還需要掌握開發(fā)平臺(tái)常用的開發(fā)工具、模式和通用框架。
6、框架與技術(shù)棧
除了學(xué)習(xí)特定的編程語(yǔ)言和平臺(tái)外,學(xué)習(xí)并掌握一個(gè)框架和技術(shù)棧也是非常重要的。
框架是一組用于在特定平臺(tái)或多個(gè)平臺(tái)上開發(fā)代碼的庫(kù),它通常會(huì)使該平臺(tái)上的常見編程任務(wù)更加容易。例如,大多數(shù)C#開發(fā)人員使用.NET Framework編寫C#應(yīng)用程序。.NET Framework由許多庫(kù)和類組成,允許C#開發(fā)人員在更高層次的抽象中工作。
技術(shù)棧則與框架有點(diǎn)不同,技術(shù)棧是一組通常包括框架的技術(shù),通常一起用于創(chuàng)建完整的應(yīng)用程序。技術(shù)棧使得創(chuàng)建應(yīng)用程序變得更加容易, 因?yàn)樗鼈兲峁┝嗽S多開發(fā)人員用于開發(fā)應(yīng)用程序的常見范例,因此可以輕松共享知識(shí)。學(xué)習(xí)技術(shù)棧是非常有價(jià)值的,因?yàn)檫@意味著你擁有開發(fā)完整應(yīng)用程序所需的所有技能。許多使用特定技術(shù)棧開發(fā)應(yīng)用程序的公司,也在尋找熟悉該技術(shù)棧的軟件開發(fā)人員。
7、數(shù)據(jù)庫(kù)基礎(chǔ)知識(shí)
目前, 主要有兩種數(shù)據(jù)庫(kù)技術(shù):關(guān)系數(shù)據(jù)庫(kù)和文檔數(shù)據(jù)庫(kù)。
現(xiàn)在的開發(fā)人員應(yīng)該很熟悉關(guān)系數(shù)據(jù)庫(kù),但同時(shí)也應(yīng)該對(duì)文檔數(shù)據(jù)庫(kù)有所了解。
在軟件開發(fā)中,數(shù)據(jù)庫(kù)通常用于存儲(chǔ)應(yīng)用程序的數(shù)據(jù)。
對(duì)于數(shù)據(jù)庫(kù),開發(fā)人員至少應(yīng)該了解以下方面:
? 數(shù)據(jù)庫(kù)的工作原理
? 如何執(zhí)行基本查詢來獲取數(shù)據(jù)
? 如何插入、更新和刪除數(shù)據(jù)
? 如何添加數(shù)據(jù)集
8、源代碼管理
管理源代碼是任何軟件開發(fā)項(xiàng)目不可或缺的組成部分。在使用源代碼之前,應(yīng)該有一個(gè)網(wǎng)絡(luò)來共享項(xiàng)目的所有文件。
源代碼管理工具最基本的功能,是保留軟件項(xiàng)目中對(duì)文件所做更改的歷史記錄。它還允許多個(gè)開發(fā)人員同時(shí)處理相同的代碼, 并將這些處理代碼融合在一起。
所有的開發(fā)人員都應(yīng)該知道如何使用源代碼管理工具,以便能夠檢查代碼并從多個(gè)來源融合代碼。
9、構(gòu)建和部署
目前,大多數(shù)軟件開發(fā)項(xiàng)目都有一些自動(dòng)化的構(gòu)建和部署系統(tǒng)。同時(shí)也有許多不同的軟件應(yīng)用程序,來幫助團(tuán)隊(duì)自動(dòng)化構(gòu)建和部署任務(wù)。
構(gòu)建
當(dāng)你編寫代碼并將其合入到源代碼管理系統(tǒng)中后,你想通過一些方法了解你合入的代碼是否運(yùn)行的很好,這就需要進(jìn)行構(gòu)建。構(gòu)建會(huì)編譯系統(tǒng)中的所有代碼,并確保沒有編譯錯(cuò)誤。一個(gè)復(fù)雜的構(gòu)建系統(tǒng)還可以運(yùn)行單元測(cè)試和用戶測(cè)試,或者代碼質(zhì)量檢查,并提供一些有關(guān)代碼庫(kù)當(dāng)前狀態(tài)的報(bào)告。
部署
部署系統(tǒng)負(fù)責(zé)將代碼部署到產(chǎn)品機(jī)器上,或者將其部署到某種測(cè)試環(huán)境中。
雖然開發(fā)人員不一定要成為部署方面的專家,但是了解系統(tǒng)的基礎(chǔ)知識(shí)以及構(gòu)建和部署代碼的過程也是非常的重要。
10、測(cè)試
現(xiàn)在,很多的軟件項(xiàng)目都采用了所謂的敏捷流程,軟件開發(fā)人員和測(cè)試人員合作的更加密切。代碼質(zhì)量成為了整個(gè)開發(fā)團(tuán)隊(duì)的責(zé)任,所以開發(fā)人員也需要對(duì)測(cè)試知識(shí)有一定了解。
對(duì)于開發(fā)人員來說,至少應(yīng)該熟悉以下的基本術(shù)語(yǔ):
? 白盒測(cè)試
? 黑盒測(cè)試
? 單元測(cè)試
? 邊界條件
? 測(cè)試自動(dòng)化
? 驗(yàn)收測(cè)試
11、調(diào)試
對(duì)于軟件開發(fā)人員來說,經(jīng)常會(huì)花費(fèi)90%左右的時(shí)間,來弄清楚自己的代碼為什么不起作用了。不論你從事任何語(yǔ)言的代碼開發(fā),代碼調(diào)試都是開發(fā)過程中不可缺少的一部分。
所以開發(fā)人員應(yīng)該下定決心,認(rèn)真的學(xué)習(xí)如何做到高效的調(diào)試代碼。
12、方法論
一些軟件開發(fā)團(tuán)隊(duì)在編寫代碼并完成他們的項(xiàng)目時(shí),都遵循著一些方法論。所以開發(fā)人員至少應(yīng)該熟悉諸多最常見的軟件開發(fā)方法論中的基本幾種,這里要說的就是瀑布開發(fā)和敏捷開發(fā)。
總結(jié)
盡管本文中列舉的軟件開發(fā)人員應(yīng)該了解的知識(shí)很多,其中很多知識(shí)也許正是你所不了解,但是請(qǐng)不要沮喪。我們要做的就是認(rèn)真的補(bǔ)充這些知識(shí),不斷的提高自己。
開發(fā)技能能夠保證我們開發(fā)任務(wù)的順利進(jìn)行,開發(fā)工具則能很好的提高開發(fā)效率。葡萄城控件一直致力于為廣大.NET平臺(tái)開發(fā)人員提供高品質(zhì)的開發(fā)工具產(chǎn)品。
評(píng)論