• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            歲月流轉(zhuǎn),往昔空明

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              118 Posts :: 3 Stories :: 413 Comments :: 0 Trackbacks

            ?扯了這么多,再次回到開始,C++有那么重要么?
            ?是或者不是,這個答案并不重要,而我也不能正確地給出答案。如果真要說我只能刷刷奸猾,告訴大家“因人而異”。
            ?重要的是,我們用什么樣的思路,用什么樣的態(tài)度來衡量、評價、解決這個問題。
            ?下面一段又是個老生常談,隨便到哪個搜索引擎上都能搜到一堆的話題:C++是怎么來的,它為什么而設(shè)計的,實(shí)際上人們又拿它來做什么,它有什么優(yōu)缺點(diǎn)。我接觸編程6年,其中C++占到4年,而且是我用的最好,也是最喜歡的語言。每次說到歷史這個話題我總是有一大堆羅嗦的話要說。但是實(shí)際上我對C++的感覺到的最大的特點(diǎn),卻是書多,相關(guān)的書非常多,經(jīng)典的著作相比較其它語言而言也算得上是最豐產(chǎn)的了。書多不外乎三種原因,一是流行面廣,而是流行時間長,三是難度大。C++就那一點(diǎn)點(diǎn)編譯器規(guī)則,一本ISO C++的手冊搭配其發(fā)明者Bjarne Stroustrup的《The C++ Programming Language》就把語言機(jī)制講的很清楚了,為什么它又有那么多的書來闡述一些所謂的Advanced Topics呢?因?yàn)殪`活。C++極度靈活,這種靈活并不是動態(tài)語言的那種靈活,而是在于它承載了太多的需要,導(dǎo)致它變得極度靈活化,靈活的負(fù)面意思就是太多,太復(fù)雜,使得人們太容易混淆與各種語言機(jī)制的Chaos中。似乎南師大的榮耀教授在采訪BS的時候還是BS在什么地方說過,如果C++要像現(xiàn)在的老師們這樣教他自己都不會去學(xué)。
            ?然后BS就舉了一個Hello World的例子來說明他所認(rèn)為的啟蒙C++與一般授課使用的C++差別在什么地方,并以此說明C++其實(shí)并不復(fù)雜。好吧,我們就承認(rèn)純正的C++并不難學(xué)。但是不能忘了,我們的C++的對與錯不是由我們決定的,而是編譯器。工程上用的C++編譯器絕對不會說不支持單純的,蹩腳的C-Style(不是說CStyle蹩腳,而是說C中蹩腳的部分),不會不讓你使用指針訪問內(nèi)存(指非必要的訪問,例如動態(tài)數(shù)組),甚至不會拒絕你使用一些類似于Hacker的代碼來完成一些極具技巧性和挑戰(zhàn)性的工作。好吧,既然C++都支持,那么便不能拒絕你寫出有此類特性的代碼。更加致命的事情是,它的很多高階機(jī)制,都是建立在底層機(jī)制基礎(chǔ)上。最明顯的例子就是Boost和STL。一旦編譯出錯,那么它的提示可能出在任何層面上,為了解決這些問題便又需要去學(xué)習(xí)那些較為底層的知識。C++的大坑就是這樣一點(diǎn)一點(diǎn)挖出來的。
            ?C++可供選擇的東西太多。所以BS就出了一本書,叫《The Design and Evolution of C++》,專門討論了每種機(jī)制在C++當(dāng)中被采納的背景、他們當(dāng)時的考慮、這些機(jī)制的適用范圍。雖然說這本書屬于“入門教材”的行列,但是實(shí)際上我更加傾向于將這本書看成是在你品嘗了C++大餐后的甜點(diǎn)。也就是說,盡管看起來有道理,但是作為預(yù)備知識同樣不適合,于是你只能一邊牢記大量的語言機(jī)制,一邊應(yīng)用,一邊體驗(yàn),一邊讀那些專著來糾正你的錯誤并填補(bǔ)你的不足,不可能有機(jī)會讓你只走你需要走的路,大量的知識構(gòu)成了一個扁平的知識框架,為了達(dá)到相對自由運(yùn)用的水平,你需要學(xué)習(xí)的知識、需要獲得的體驗(yàn)、需要彌補(bǔ)的弱點(diǎn)太多了。
            ?
            ?如果說,只有C++可選的話,那么也就沒什么辦法了,大家只能去學(xué)那個能讓人死去活來的東西。但是實(shí)際上我們并不如我們自己認(rèn)為的那樣無奈。大量的語言,總有比C++更加適合一般學(xué)生的。靈活的腳本語言Python/VBSP/JSP/Perl/Ruby/Lisp,半動態(tài)的(我是這么叫的。。。)Java/C#/VB/VB.NET/CLI,高效的 Ada/Fortran,桌面開發(fā)用功能強(qiáng)大的Delphi(人家的語言叫Object Pascal,但是也就那么一個編譯器,所以無所謂了),這其中的絕大部分語言學(xué)習(xí)難度都要低于C++。
            ?一般來說,有不少學(xué)校對于除了與電子和信息相關(guān)的專業(yè)都選擇的是VB(以下說的VB均不指.NET)/VFP作為計算機(jī)二級的突破口。而這點(diǎn)教學(xué),往往就成為了一個工科研究生僅有的編程基礎(chǔ)。VFP這種被淘汰的使用范圍狹隘的環(huán)境不討論,VB作為RAD來說著實(shí)是個不錯的選擇。但是為應(yīng)付計算機(jī)二級所教授的課程來看,并不能教會除了語法外的什么,況且所使用的VB6嚴(yán)格來說是Message Driven兼Object Based的一個開發(fā)環(huán)境,這都不利于學(xué)生從程序結(jié)構(gòu)的高度(不是數(shù)據(jù)結(jié)構(gòu))去思考所撰寫的代碼。在短暫的學(xué)習(xí)以后我們會誤認(rèn)為界面框架就是軟件的構(gòu)架,于是我們便可以看見在畢業(yè)設(shè)計時候,那數(shù)百行可憐的代碼都擁擠于Command1Click這樣的字里行間。Object Based的語言既不能教會我們用過程的方式開發(fā),也不能支持面向?qū)ο蟮某绦蛟O(shè)計方法。這些都是VB對進(jìn)階學(xué)習(xí)的最大障礙。
            ?但是畢竟我們熟悉了VB的語法,知道了程序設(shè)計語言是怎么一回事。這已經(jīng)花費(fèi)了沒有接觸過編程的同學(xué)的相當(dāng)長的時間,如果說我們還要去牽扯入C++那可怕的內(nèi)存海洋中,還要被C++那恐怖的前后++所威脅,但是實(shí)際上我們不需要它也能過得很好,我們是不是有些冤大頭了?
            ?實(shí)際上,對于研究生階段,最重要的就是要讓我們學(xué)到的那一點(diǎn)點(diǎn)東西在盡可能少學(xué)別的東西的情況下發(fā)揮最大的價值。
            ?前面我把VB一通好臭,我想VB都會不理我了。那么我們就另結(jié)新歡吧。找誰呢?

            ?VB的弱點(diǎn)已經(jīng)有點(diǎn)數(shù)了(很有數(shù)的話你我就不會在這兒瞎混了,早被M$請去了),那么便要去找一門結(jié)構(gòu)性比VB好,概念又不比VB艱深太多的語言(不是說它不能艱深,而是說,不理解那些艱深的東西我們一樣能用的挺歡,最主要的是用起來要舒服,什么亂七八糟的內(nèi)存管理問題,讓編譯器和RTL/VM去替你擦屁股吧)。JAVA/C#/Delphi/VB.net都算是不錯的選擇。雖然從我的角度來說,很不喜歡,非常不喜歡,特別不喜歡微軟,但是我仍然將C#作為我的第一建議。
            ?因?yàn)镃#的開發(fā)環(huán)境好,速度也還算不錯,桌面開發(fā)、企業(yè)級開發(fā)都很方便,微軟的支持也很到家,但是對面向?qū)ο蟮闹С钟行?qiáng)迫性了,可能初期會有些難度。
            ?JAVA跨平臺,工業(yè)基礎(chǔ)好,從嵌入式到大型的分布式系統(tǒng)都能拿來做,但除了和C#一樣的不利因素外,開發(fā)環(huán)境和程序庫要比C#難用一些。
            ?Delphi對對象和過程的程序設(shè)計方法都能支持良好,語言干凈利索,檢測嚴(yán)格,能培養(yǎng)出一個人好的編程習(xí)慣,但是它以后用途偏窄。
            ?VB.NET就不用說(人家都叫VB了),跟VB比較接近,語法跨越小,但是太小了會有學(xué)習(xí)惰性,會低估語義和程序設(shè)計方法上的差異,弄點(diǎn)不倫不類的東西出來。

            ?C++在程序控制上的能力,基本上都有了,而在在企業(yè)級開發(fā)方面,C++的弱勢也得到了新語言不錯的彌補(bǔ)。C++的另一個優(yōu)勢,效率方面呢?
            ?MATLAB。這個工具生來就是為了計算。作為研究生的工程運(yùn)算來說,無論效率上還是功能上來說,通常都是夠用的,而且也非常方便,避免了自行編程所面對的極為復(fù)雜的算法選擇、編寫、調(diào)試的問題(工程計算程序的調(diào)試難度是很大的)。
            ?再加上VBA/VBSP。為什么要帶上VBA/VBSP?其實(shí)很多你需要完成的功能,往往都在軟件中可以通過調(diào)用某些組件來完成。除了脫機(jī)編寫完整的應(yīng)用程序以外,對于大部分的問題的解來說,都可以直接使用系統(tǒng)所提供的環(huán)境方便的完成。使用這個環(huán)境所采用的語言,就是軟件的腳本宏,而現(xiàn)有很多的軟件所采用的宏語言都是VBA/VBSP。它的語法、架構(gòu)、程序的設(shè)計都與VB非常接近,用來快速的構(gòu)造原形或?yàn)榫帉憣?shí)驗(yàn)提供幫助的程序來說,都能比較好的完成任務(wù)。

            ?好了,在一門通用語言+VBSP+MATLAB的幫助下(VBSP基本上是白送的,MATLAB經(jīng)常是必須掌握的,如果你不需要掌握MATLAB,那么你的工作很可能也用不到C++的高效率),你還需要C++么?
            ?如果你的答案是肯定的,那么我只能相信這個世界真的有愛情存在。我欽佩你的執(zhí)著。那么請允許我告訴你我走過的路。
            ?《The C++ Primer》/《The C++ Primer Plus》??不是一本書,但是都是入門的。別為它的厚度嚇倒,能看多少算多少,不難的。
            ?《The C++ Programming Language》???手冊。隨身必備,供查閱。
            ?Platform SDK???????MSDN是個不錯的選擇,講解相近,查閱方便。
            ?
            ?《Thinking in C++》??????從C++開始,接觸OOP的深入解析
            ?《Effective C++》《More Effective C++》
            ?《Exceptional C++》《More Exceptional C++》??技巧、技術(shù)和技藝,編寫C++程序必須注意的若干事項。
            ?
            ?基本上到這里就差不多了,后面的就是諸如泛型、并發(fā)、元編程、模版、設(shè)計模式一類的話題了,不同的話題都有不同的問題背景和應(yīng)用范圍,這些往往對于大部分語言來說都是相同或者類似的。恭喜你,你們的愛情長跑到站了。
            ?從此以后,研究生和C++過著磕磕碰碰卻幸福的生活。

            posted on 2006-10-13 21:32 空明流轉(zhuǎn) 閱讀(1921) 評論(6)  編輯 收藏 引用

            評論

            # re: 研究生,請你拒絕C++的愛(下) 2006-10-18 17:39 duanxingchuan
            我也差點(diǎn)被C++被害苦了!!!!!!幸好我覺悟的早!  回復(fù)  更多評論
              

            # re: 研究生,請你拒絕C++的愛(下) 2006-10-20 16:50 wbt
            智商低的還是別玩,免得自己被玩,哈哈  回復(fù)  更多評論
              

            # re: 研究生,請你拒絕C++的愛(下) 2007-05-12 16:09 lovedday
            我覺得你神話了C++的難度,C++固然很復(fù)雜,但如果你狠下心來研究,也一定可以掌握的,一門語言再復(fù)雜都不會復(fù)雜到什么程度,夸大語言的作用和復(fù)雜度都是不好的,你說C++會比編譯原理更復(fù)雜嗎?對于一個學(xué)習(xí)的人來說,最重要的是克服恐懼的心理,如果你覺得C++很難很復(fù)雜,那你就肯定學(xué)不會了。而且很多人使用C++都不用C++的那些復(fù)雜的高級特性,語言嘛,夠用就可以了,沒必要非得掌握它的所有語言特性,BS不是說過嗎?沒人能夠徹底掌握C++。從某種意義上說,復(fù)雜并不是一件好事,我喜歡簡單的東西,簡單就是美,在實(shí)際的開發(fā)過程中,效率是非常重要的,如果你對C++的復(fù)雜語言特性掌握的不牢固卻非要使用那些語言特性,那么出了錯就會浪費(fèi)很多的時間。  回復(fù)  更多評論
              

            # re: 研究生,請你拒絕C++的愛(下) 2007-05-12 16:10 lovedday
            而且我覺得在計算機(jī)領(lǐng)域,掌握基礎(chǔ)知識和技術(shù)原理比研究語言的高級語法特性更重要。  回復(fù)  更多評論
              

            # re: 研究生,請你拒絕C++的愛(下) 2007-05-20 14:33 Jedimaster
            C++就是為妄圖重新發(fā)明世界的天才們設(shè)計的魔方。我覺得,設(shè)計第一,思路第二,算法第三,編碼第四。  回復(fù)  更多評論
              

            # re: 研究生,請你拒絕C++的愛(下) 2014-10-21 13:55 yuen
            看了幾次學(xué)長寫的東西,尤其是這個。
            深深覺得學(xué)長說的是正確的。如果一年前我能多看看學(xué)長的東西,恐怕不會在C++上浪費(fèi)了如此多的精力和金錢。。。。。
            感謝學(xué)長美文,以享莘莘工科狗!thx!  回復(fù)  更多評論
              


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            国产2021久久精品| 久久久久国产日韩精品网站| 亚洲国产精品无码久久| 亚洲国产精品久久电影欧美| 久久久久人妻一区精品色| 久久综合精品国产二区无码| 久久99精品国产| 久久久久久国产a免费观看不卡| 一级a性色生活片久久无| 国产精品无码久久综合| 久久久久久av无码免费看大片| 亚洲日本va中文字幕久久| 99久久精品国内| 性做久久久久久久久浪潮| 久久精品成人免费网站| 久久国产劲爆AV内射—百度| 国产99久久久久久免费看| 2021国产精品久久精品| 狠狠色噜噜狠狠狠狠狠色综合久久 | 久久久91人妻无码精品蜜桃HD| 久久久久亚洲AV无码观看 | 久久精品国产一区二区三区日韩| 国产一久久香蕉国产线看观看| 97精品国产97久久久久久免费| 欧美亚洲国产精品久久蜜芽| 精品国产乱码久久久久久浪潮| 精品无码久久久久久午夜| 国产精品久久久久免费a∨| 国产成人精品久久一区二区三区av | 色婷婷综合久久久久中文字幕 | 三级三级久久三级久久 | 日本人妻丰满熟妇久久久久久 | 亚洲国产精品无码久久98| 欧美国产精品久久高清| 国产AⅤ精品一区二区三区久久| 国产精品久久久久9999| 久久精品中文騷妇女内射| 狠狠色综合网站久久久久久久高清 | 久久久久久精品免费免费自慰 | 免费精品99久久国产综合精品 | 国产午夜精品久久久久九九|