語言沒有好壞之分,只有對某個(gè)問題的處理擅不擅長,具體還得看你自己的需求。
成都創(chuàng)新互聯(lián)公司于2013年開始,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都做網(wǎng)站、網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢想脫穎而出為使命,1280元永修做網(wǎng)站,已為上家服務(wù),為永修各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:028-86922220
VB.NET確實(shí)還行,C語言大家都知道效率比較高,應(yīng)用也更廣泛些,還是推薦你學(xué)C語言,學(xué)好C語言之后再學(xué)C#比VB.NET稍微好學(xué)些,都是.NET
總得來說,語言可以分為兩種,一種是面向?qū)ο?一種是面向過程.(想要學(xué),就去買本書回來慢慢看.)
我學(xué)了一年多的編程了,總學(xué)過C語言,VB.NET,C++.
其中,覺得,C++要學(xué)好,需要下太大的資本了.也要有一些條件!
不過,C++和java有一個(gè)大的區(qū)別,就是C+無論做一個(gè)項(xiàng)目,需要?jiǎng)?chuàng)建許多的類.而java本身就已經(jīng)具有那些類了,只要你調(diào)用下就ok.不過,C+那樣用戶創(chuàng)的類,實(shí)用,靈活方面,就比較實(shí)在!不過,說白了點(diǎn),就是麻煩..你看著自己的意愿發(fā)展吧!不能全學(xué)語言,要專攻一門.
C#和VB.net本質(zhì)上都是.net框架下的,除了語法上有一些差別,兩者可認(rèn)為是同樣的。稍有不同的是VB.NET繼承VB的弱類型機(jī)制,沒有C#對數(shù)據(jù)類型的規(guī)定得嚴(yán)格。
就.net框架來說說優(yōu)缺點(diǎn)吧。優(yōu)點(diǎn):開發(fā)簡單,支持的語言多,有很豐富的現(xiàn)成的類庫可以使用,不必編寫底層代碼,只需關(guān)注業(yè)務(wù)邏輯。
缺點(diǎn):僅支持windows系統(tǒng),可移植性差;在性能上和對系統(tǒng)底層控制上不如C/C++。
VB.net完全是為了讓VB程序可以再.Net平臺上運(yùn)行而存在的,其本身就是一堆缺點(diǎn),運(yùn)行效率上沒有VB高,對象取得也沒有VB方便,語法和VB基本一樣,所以編寫起來也麻煩,雖然是.Net框架下的語言,但對.Net的支持又不是很好,卻又因?yàn)?Net拖慢了VB自傲的高速。
C#就完全不同了,他就是給.Net寫的,肯定是對.Net支持最好的語言了,而且語法也比較簡單,和C、C++、Java的語法是一樣的,只是.Net的類庫和這三種語言不同,所以實(shí)際寫代碼時(shí),比VB、VB.net、C、C++、Java都要簡單
Visual Basic.net還是C#
——如何選擇.net語言
在.net中,如何選擇VB或C#?這似乎已經(jīng)爭論了很久。很多人盲目選擇,也產(chǎn)生了許多流言和錯(cuò)誤。本文將從以下方面指導(dǎo)你選擇正確的開發(fā)語言。
功能上的考慮
許多人認(rèn)為C#的功能比VB.net強(qiáng)大,或者C#更加適合.net等。其實(shí)這不是一兩句話能比較清楚的。C#的確有VB無法完成的功能,但VB也有C#無法完成的功能。總的來說,對于.net開發(fā),VB和C#沒有任何差別,都100%兼容于CLS。下面列出的是他們語言功能上的不同,這些僅僅是語言實(shí)現(xiàn)上的問題,不會影響到生成的代碼。打*號的內(nèi)容與CLS不兼容。
C#有而VB沒有的功能:
1、 運(yùn)算符重載。*
2、 不安全代碼(指針和固定內(nèi)存區(qū))。*
3、 無符號整數(shù)。*
4、 移位運(yùn)算。
VB有而C#沒有的功能
1、 即時(shí)編譯。
2、 靜態(tài)事件綁定。
3、 條件異常捕獲。
4、 COM兼容類。*
5、 寬松的類型檢查和變量聲明。
6、 Visual Basic Runtime庫。
7、 可選參數(shù)、帶參數(shù)屬性、模塊等語言特征。*
8、 動(dòng)態(tài)數(shù)組。*
可見,實(shí)際上功能更強(qiáng)大的是VB而不是C#。不過它們不一樣的地方多半是無關(guān)緊要的特征??傮w上來說,不應(yīng)從功能上選擇VB或者C#,因?yàn)樗麄儧]有什么具體的差別。
性能上的考慮
性能是程序員最關(guān)心的問題。VB和C#都生成一樣的IL,因此理論上說不會有性能的差異。但許多人為什么說C#的性能高于VB.net呢?這是因?yàn)閂B.net支持即時(shí)編譯,就是一邊書寫代碼一邊編譯。這樣可立刻發(fā)現(xiàn)語法錯(cuò)誤,使調(diào)試變得更加容易。但是這樣一來VB就需要隨時(shí)瀏覽整個(gè)代碼文件,并把臨時(shí)數(shù)據(jù)儲存。這造成VB.net生成的代碼中常常具有冗余部分。但也不能就此下結(jié)論說VB比C#慢,當(dāng)用戶選擇打開優(yōu)化并且以Release方式編譯工程,就能得到與C#一樣簡短快速的代碼。
學(xué)習(xí)上的難度
這部分不僅僅初學(xué)者需要考慮,那些從現(xiàn)有開發(fā)工具轉(zhuǎn)移到.net的開發(fā)人員也需要考慮。首先,VB和C#都是非常簡單的,對于初學(xué)者來說,VB提供伸縮性更強(qiáng)的空間,因此比C#更加易于接受。但這只是相對而言,C#對于初學(xué)者來說也不會有太多的困難。
對于使用Visual Basic6或其他版本的程序員來說。VB.net的語法顯然要比C#更加接近VB6,網(wǎng)上流傳的VB與VB.net差別被過分夸大,使部分程序員退縮。其實(shí)VB.net增加的只是面向?qū)ο蟮乃枷耄S多VB程序員不具備完善的面向?qū)ο缶幊涕_發(fā)經(jīng)驗(yàn),因此覺得VB.net難以接受,這是很容易克服的。想想看,即使你要使用C#不也得學(xué)習(xí)面向?qū)ο髥??至于有C/C++/Java經(jīng)驗(yàn)的人,C#是小菜一碟。剛才說過C#和VB實(shí)際上都很簡單,所以不見得VB程序員學(xué)習(xí)C#就要比C/C++程序員來的困難,反之亦然,有C/C++經(jīng)驗(yàn)的人也可以果斷的選擇VB。
移植現(xiàn)有代碼
這一部分是程序員最頭疼的部分。但對語言選擇有決定性的意義。
從VB6移植代碼的程序員,最佳選擇就是VB.net,因?yàn)槠渌?net語言沒有一種是與VB相似的。而且即使VB6的工程移植到VB.net非常困難,也有一個(gè)移植向?qū)Э梢詭椭阃瓿纱蟛糠止ぷ?。如果手工把他移植到C#,需要白白花費(fèi)大量的時(shí)間。而且剛開始使用C#的VB程序員通常都會為C#缺少他們熟悉的函數(shù)而頭疼。VB.net不會出現(xiàn)這種情況。
從ASP移植到ASP.net,首選語言仍然是VB.net,因?yàn)槎鄶?shù)程序員使用的ASP語言是VBScript,只有VB.net最大程度地接近這種語言。
C#對于移植代碼似乎沒有作用,了解C#的人都明白,把現(xiàn)有C/C++代碼放到C#中運(yùn)行幾乎是100%不能通過的。所以,如果需要移植C/C++代碼,最好使用Visual C++.net。他做到了最好的新舊結(jié)合。C#僅僅用于編寫新的.net應(yīng)用程序。
如果需要從Java移植代碼,C#可以選擇。同時(shí)還有J#及其他一些MS提供的轉(zhuǎn)換工具。
文檔和資源方面的考慮
在MSDN文檔中,C#和VB是同等看待的。所有文檔和例子都是有VB和C#兩份的。因此,在尋求資源方面都不用擔(dān)心。互聯(lián)網(wǎng)上的資源,C#要多于VB,特別是國內(nèi),有傾向于C#的潮流。但是ASP.net的資源VB較多。國內(nèi)缺乏VB.net資源是影響VB.net推廣的重要原因。但是在國外有很多非常成熟的VB技術(shù),如掌上設(shè)備的開發(fā)技術(shù)。
代碼風(fēng)格和雜項(xiàng)問題
C#書寫的代碼比VB平均短小20%,許多人不喜歡VB中過長的關(guān)鍵字。當(dāng)然他們可以選擇C#。但在開發(fā)環(huán)境中,VB的自動(dòng)完成功能比C#更完善,其實(shí)30%的代碼都是自動(dòng)補(bǔ)充的。因此,實(shí)際上VB程序員不會比C#多打多少字。但VB語言換行比C#麻煩,如果需要書寫大量繁雜而長的代碼,最好選擇C#。VB的代碼接近完整的英語,比C#更加易讀。如果是初學(xué)者不妨選擇VB。
c吧,初學(xué)上手比較難,但還在用,其他語言好多講效率的基礎(chǔ)庫底層都是c寫的。
另外好多語言都是c語言體系的,基本都差不多什么if,else,switch啥的。
vb相對簡單,但不算很大眾。c#,java這種比較主流上手也快,但也是c體系的??茨阋陕锪?/p>
當(dāng)前標(biāo)題:c和vb.net,c和vbnet哪個(gè)好學(xué)
路徑分享:http://weahome.cn/article/dsepooh.html