總是被同學(xué)們問到,如何學(xué)習(xí)C和C++才不茫然,才不是亂學(xué),想了一下,這里給出一個總的回復(fù)。
一家之言,歡迎拍磚哈。
1、可以考慮先學(xué)習(xí)C.
大多數(shù)時候,我們學(xué)習(xí)語言的目的,不是為了成為一個語言專家,而是希望成為一個解決問題的專家。做一個有用的程序員,做一個賺錢的程序員。我們的價值,將體現(xiàn)在客戶價值上,而不是語言寫得好不好看。
C++是C的一個面向?qū)ο蟮慕忉?,C++為C擴充了大規(guī)模工程應(yīng)用,復(fù)雜的系統(tǒng)結(jié)構(gòu)的組織和掌控方法,但是,我認(rèn)為,C++骨子里還是C的。
畢竟,解決具體問題,每個函數(shù)內(nèi)部,都是用C的方式寫程序,還是面向過程的。
因此,想要學(xué)習(xí)好C++,我的建議,先學(xué)習(xí)C,先學(xué)解決問題的能力,再討論解決大問題的能力。就是先學(xué)習(xí)怎么走路,再學(xué)習(xí)怎么跑步。
2、學(xué)習(xí)C的過程中,一定要理解結(jié)構(gòu)化編程思維。
為什么呢,我前面有文章說過,軟件語言的發(fā)展過程,就是一個數(shù)據(jù)私有化的過程,大型工程應(yīng)用,強調(diào)高內(nèi)聚,低耦合,模塊化設(shè)計,保持代碼最大的靈活性和安全性。
這是現(xiàn)代工程化開發(fā)的核心和靈魂。
因此,利用C這門語言入門,借此理解結(jié)構(gòu)化開發(fā)思維,可以說是個很方便的路子。因為C的函數(shù),本來就是為重用做準(zhǔn)備的。同時,全局變量和cpp內(nèi)部私有變量的差別,其使用原則,這些都能學(xué)到很多結(jié)構(gòu)化開發(fā)思維。
3、開始學(xué)習(xí)C++
C++不難學(xué)的,很多人覺得C++難學(xué),其實是因為它在C之外,又提供了很多的概念,尤其是對象,很難以理解。
不過我經(jīng)過這么多年,把這個問題反而看淡了,我認(rèn)為面向?qū)ο笙鄬γ嫦蜻^程,僅僅是結(jié)構(gòu)化程序設(shè)計的一個具體體現(xiàn),是編譯器提供手段,強迫程序員必須遵循數(shù)據(jù)私有化的一個實例,C++和C的關(guān)系,最核心的莫過于此。
現(xiàn)在我們回到C再看看,如果我們把一個全局變量,寫到一個cpp里面,并且在對應(yīng)的h文件中不聲明,它是不是就只有這個模塊可以使用?它是不是就是私有變量,以這個理解,類能明白了嗎?
4、學(xué)習(xí)C++的深入技巧
C++在類的基礎(chǔ)上,經(jīng)過這么多年的發(fā)展,其實提供了很多深入的概念,看起來很復(fù)雜,其實我看也很簡單。比如模板,我的理解就是“類的類”,大家說是不是?
既然模板理解了,STL,ATL這些,靜態(tài)模板庫,動態(tài)模板庫,還難理解嗎?就是一大堆類的類,可以借此實現(xiàn)很多應(yīng)用中需要的類,不需要程序員再自己寫而已。
ok,STL都理解了,泛型開發(fā)還難嗎?所謂泛型開發(fā),其實就是我做一個模板,來定義一套算法規(guī)則,但是呢,我希望這個算法規(guī)則,能進一步抽象,對核心數(shù)據(jù)類型不要限死,我把各種數(shù)據(jù)套進去,都可以用,這樣,僅算法這部分,我不需要重寫了。你想想是不是這個道理?
學(xué)到這里,C++和C,其實已經(jīng)差不多了。再學(xué)語言,就是求全責(zé)備,過于鉆牛角尖了。
5、學(xué)習(xí)應(yīng)用開發(fā)
前面說了,學(xué)習(xí)語言,目的不是讓別人認(rèn)為自己是專家,是為了寫程序賺錢。因此,語言學(xué)完,要學(xué)習(xí)應(yīng)用開發(fā)。
什么叫應(yīng)用開發(fā)呢,我會一門語言,但是,客戶不懂,客戶說的很直接,在Windows下給我寫個程序,我要什么什么功能。為啥Windows呢?因為我習(xí)慣。
OK,很多時候,應(yīng)用開發(fā)要尊重客戶習(xí)慣,一般說來,語言這個東東,還是要結(jié)合具體平臺的開發(fā),才能開發(fā)出有意義的應(yīng)用程序賣錢。那么,一般說來,客戶端是Windows系統(tǒng),服務(wù)器是Linux,這些都是行業(yè)習(xí)慣,嵌入式不好說,各種平臺都有,Palm,S60,Linux,WinCE,等等。要根據(jù)自己的目標(biāo)客戶來定。
當(dāng)我們選定目標(biāo)平臺后,有一個問題,選什么語言,很多時候,學(xué)生和商用程序員差別就在這里,學(xué)生一般沒得選,自己會啥就用啥唄,企業(yè)里的程序員不會,要先評估需求,看哪個語言更合適,不會的語言,要去學(xué)。
ok,假定我們選了C和C++,那么,我們需要選擇開發(fā)平臺,Windows下不用說了,VC,這是最好用的,Linux下呢,gcc,其他的也差不多。
假如我們開發(fā)VC,并且使用C++,這個時候,才需要考慮學(xué)習(xí)MFC了,因為這是微軟的標(biāo)準(zhǔn)類庫,至少Windows平臺下,它最權(quán)威,你看見沒有,我們從學(xué)習(xí)開始,走了多少步,才走到MFC?是不是MFC不是學(xué)習(xí)C++上來就必須學(xué)的?
6、學(xué)習(xí)MFC
學(xué)習(xí)MFC,很多人一上來就開始看其體系架構(gòu),看得一頭霧水,那個模塊關(guān)系依賴圖,我到現(xiàn)在都看不懂。
呵呵,其實不是啦,和學(xué)語言一樣,我們學(xué)MFC的目的,也不是希望成為MFC的專家,而是要利用MFC開發(fā)Windows應(yīng)用程序,為我們賺錢??匆姏]?MFC是手段,不是目的,目的是開發(fā)Windows程序。
其實Windows下,有一套很標(biāo)準(zhǔn)的C接口,叫Win32API,這個才是Windows的標(biāo)準(zhǔn)編程核心,因此,學(xué)習(xí)MFC,真實的目的是理解Windows程序開發(fā),建議可以先學(xué)習(xí)Win32API,看來我們又回到C了哈,呵呵。剛開始學(xué)C有用吧?
7、Win32API
其實Win32APi不難學(xué)的,因為雖然它很大,有很多接口,但不是必須的,我們真正做個簡單的Windows應(yīng)用,其實用不到這么多的。做個簡單的Dialog,然后實現(xiàn)個功能,你遇到的接口函數(shù),其實絕大多數(shù),就是以后常用的了。把常用的記熟練,就ok了。
關(guān)鍵是,這個時候要通過WinMain方式,去理解Windows的事件機制,這是核心,其實說起來簡單得要死。就是以前你的程序,由于沒有系統(tǒng)支撐,很多事必須自己做,比如檢查鼠標(biāo)和鍵盤輸入,你需要寫個死循環(huán),自己不斷去看,而Windows說,這些事你不要做了,我來做比你好。你沒事就玩去吧,我把和你相關(guān)的消息放到一個隊列里,就是你的事件隊列,你自己沒事去找找看,有沒有新消息來,有就做事,沒事就玩好了。很簡單是不?
當(dāng)然,Windows是多任務(wù)操作系統(tǒng),有時候,我們的邏輯需要并發(fā)一些功能,比如說,我在等鼠標(biāo)鍵盤消息的時候,需要再看看打印機準(zhǔn)備好了沒有,這里就需要理解并行計算了,這和語言無關(guān),和操作系統(tǒng)無關(guān),這是另外一個話題,這里不多說了,你可以自己找找線程開發(fā)的相關(guān)資料看。
看見沒,為了學(xué)習(xí)好Windows編程,其實我們不僅僅需要學(xué)習(xí)語言,還要學(xué)習(xí)操作系統(tǒng),并行計算原理,內(nèi)存原理,可能有時候還需要學(xué)習(xí)網(wǎng)絡(luò)通信,等很多知識,所以說,單憑學(xué)習(xí)語言,是成不了商用程序員的,一個合格的程序員,需要理解的東西,太多了,要廣為學(xué)習(xí)。
當(dāng)我們把Win32API,以及基本的窗口化程序設(shè)計理解了,就可以回到MFC繼續(xù)學(xué)習(xí)了。是不是有點遞歸返回的意思?呵呵。
8、回到MFC
原來學(xué)MFC很難的,因為其封裝了太多細(xì)節(jié),很難理解透徹。不過還好,我們有侯老師的深入淺出MFC,去找本來看看,如何從Win32API的純C編程,改變?yōu)镸FC的C++方式,看這個最快,基本上前6章看完,已經(jīng)會了,這里我就不多說了。
9、COM
COM、COM、COM,我最頭疼的COM,呵呵。
COM就是一種遠(yuǎn)程過程調(diào)用,即你請求的代碼是在另外一個進程中運行的,通過某種通信協(xié)議來回傳遞參數(shù)和結(jié)果。僅此而已。DCOM進了一步,服務(wù)者可以在另外一臺計算機上。在公司開發(fā)中,大家可能各做一塊,如果要合作,Windows下建議多使用COM.(我個人喜歡socket通信哈)
簡單說,COM提供了一種機制,可以跨進程通信,甚至跨機器通信。不過,為了傳遞各種類型的參數(shù),COM可謂是無所不用其極,它發(fā)明了智能指針,可以指向任何類型的數(shù)據(jù),同時,為了實現(xiàn)智能指針,它使用了大量的C++泛型設(shè)計,看見沒,C++的基本功就起作用了,還用到了ATL.
學(xué)習(xí)COM,要注意一個接口的概念。由于開發(fā)者是不同的人,調(diào)用程序和服務(wù)程序,可能不是同一種語言,OK,不能簡單提供一個C或C++的。h文件來解答接口,因此,COM提供了標(biāo)準(zhǔn)接口,使用者在程序內(nèi)部,以查詢方式獲得可用接口,進而以接口ID調(diào)用。很累人的。
學(xué)會了COM,就可以多理解一點ActiveX了,那么再學(xué)習(xí)一點dll(動態(tài)鏈接庫)的知識,我們就已經(jīng)可以寫OCX控件了。一般說來,OCX控件是個很好的設(shè)計,哪都能用,一個軟件的模塊,最理想是開發(fā)成這個樣子,比exe靈活。
評論
查看更多