青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

C++ Programmer's Cookbook

{C++ 基礎(chǔ)} {C++ 高級(jí)} {C#界面,C++核心算法} {設(shè)計(jì)模式} {C#基礎(chǔ)}

超越 C++ 下一代 C++ — C++/CLI簡(jiǎn)介(轉(zhuǎn)載)

 

一、緒論

當(dāng)微軟推出VS.NET7實(shí)現(xiàn)了可擴(kuò)展的托管C++后,C++程序員們反映不一。盡管大部分的程序員對(duì)于能夠繼續(xù)使用C++感到很欣慰,但幾乎所有的人對(duì)于托管C++提供的晦澀語(yǔ)法感到很痛苦。微軟明顯從反饋中感覺(jué)到托管C++不是那么成功。

2003年10月6日,ECMA(歐洲計(jì)算機(jī)制造商協(xié)會(huì))宣布成立專家組,負(fù)責(zé)結(jié)合ISO標(biāo)準(zhǔn)C++與通用語(yǔ)言,開(kāi)發(fā)一個(gè)可擴(kuò)展語(yǔ)言的標(biāo)準(zhǔn),這個(gè)新的可擴(kuò)展語(yǔ)言被稱為C++/CLI標(biāo)準(zhǔn)。這個(gè)標(biāo)準(zhǔn)將被VS.NET2005的C++編譯器支持。

二、老語(yǔ)法存在的問(wèn)題

1、晦澀繁瑣的語(yǔ)法和文法--這兩個(gè)"雙重底線"問(wèn)題加重了閱讀的負(fù)擔(dān)。

2、二流的CLI支持--相對(duì)與C#與VB.NET,MC++使用不方便的工作區(qū)來(lái)提供CLI支持,例如,它沒(méi)有一個(gè)一一對(duì)應(yīng)的結(jié)構(gòu)來(lái)列舉.NET的集合。

3、C++與.NET粗陋地結(jié)合--對(duì)于CLI類型,你不能使用C++的特色,例如模板;同樣,對(duì)于C++類型,你不能使用CLI的特色,例如碎片帳集。

4、令人混淆的指針--非托管的C++的指針及托管的引用指針都使用*語(yǔ)法,這非常令人混淆,因?yàn)?gc指針與托管指針在本質(zhì)和行為上完全不同。

5、MFC編譯器不能產(chǎn)生可校驗(yàn)的代碼。

三、C++/CLI給我們提供了什么?

1、優(yōu)雅流暢的語(yǔ)法和文法--C++/CLI為C++開(kāi)發(fā)人員書寫托管代碼提供了一種非常自然的感覺(jué),并且它提供了非托管代碼到托管代碼的平滑過(guò)度。以前所謂的"雙重底線"問(wèn)題現(xiàn)在已經(jīng)蕩然無(wú)存。

2、一流的CLI支持--CLI特色,例如屬性、碎片集合和屬類得到了直接支持,此外,C++/CLI還準(zhǔn)許將這些特色用于本地非托管的類。

3、一流的C++類支持--C++特色,例如模板和析構(gòu)函數(shù)對(duì)于拖管和非拖管類繼續(xù)有效。實(shí)際上,C++/CLI是你可以"表面上"在棧或C++本地堆上聲明一個(gè).NET類型唯一的.NET語(yǔ)言。

4、在.NET與C++之間的溝壑上架起了一座橋梁--C++開(kāi)發(fā)人員在抨擊BCL時(shí)不再象離開(kāi)水的魚。

5、C++/CLI編譯器產(chǎn)生的可執(zhí)行文件完全是可校驗(yàn)的。

四、"Hello World"小程序

using namespace System;
            void _tmain()
            {
            Console::WriteLine("Hello World");
            }

上述代碼除了不需要引用mscorlib.dll庫(kù)外,與老的語(yǔ)法沒(méi)有太大的區(qū)別,因?yàn)闊o(wú)論你什么時(shí)候使用/clr進(jìn)行編輯,編譯器都可以暗中進(jìn)行引用(現(xiàn)在默認(rèn)的是/clr:newSyntax)。

五、句柄

與老的語(yǔ)法主要的混淆是我們習(xí)慣于使用*符號(hào)來(lái)聲明拖管引用或非拖管指針,在C++/CLI里微軟引入了句柄的概念。

void _tmain()
            {
            //The ^ punctuator represents a handle
            String^ str = "Hello World";
            Console::WriteLine(str);
            }

^符號(hào)代表一個(gè)托管對(duì)象(聲明時(shí)看上去象個(gè)帽子),按照CLI的規(guī)定,句柄代表一個(gè)拖管對(duì)象的引用。句柄在CLI中是新的語(yǔ)法,相當(dāng)于C++中的-gc指針。句柄與指針不再混淆,在本質(zhì)上兩者完全不同。

六、句柄與指針是怎樣區(qū)分開(kāi)來(lái)的?

1、指針聲明時(shí)使用*符號(hào),而句柄使用^符號(hào)。

2、句柄是針對(duì)拖管堆上對(duì)象的拖管引用,而指針僅僅指向內(nèi)存中的一個(gè)地址。

3、指針很穩(wěn)定,GC循環(huán)不會(huì)影響到它;句柄在基于GC或內(nèi)存緊張的情況下,可以指向不同的內(nèi)存位置。

4、對(duì)于指針,程序開(kāi)發(fā)人員必須"顯式"地刪除,否則會(huì)面臨泄露的危險(xiǎn),而對(duì)于句柄,是否進(jìn)行顯式刪除則完全根據(jù)程序人員的愛(ài)好了。

5、句柄一定要指向一個(gè)具體的類型,即所謂的類型安全性,而指針明顯不是這樣,你決不可以將一個(gè)句柄指向Void^類型。

6、正如new操作符返回一個(gè)指針一樣,gcnew返回一個(gè)句柄。

七、CLR對(duì)象示例

void _tmain()
            {
            String^ str = gcnew String("Hello World");
            Object^ o1 = gcnew Object();
            Console::WriteLine(str);
            }

關(guān)鍵字gcnew用來(lái)實(shí)例化一個(gè)CLI對(duì)象,而且它返回一個(gè)指向在CLR堆上的對(duì)象的句柄,gcnew的優(yōu)點(diǎn)在于它可以方便的讓我們區(qū)分拖管和非拖管的實(shí)例對(duì)象。

大部分情況下,gcnew關(guān)鍵字和^操作符提供了你用來(lái)進(jìn)行BCL的一切手段,但是很明顯你需要?jiǎng)?chuàng)建和聲明屬于自己的拖管類和接口。

八、聲明類型

CLR類型有一個(gè)形容詞前綴用來(lái)說(shuō)明類型的種類,下面是C++/CLI中的類型聲明示例:

1、 CLR types
            o Reference types
            § ref class RefClass;
            § ref struct RefClass;
            2、 Value types
            § value class ValClass;
            § value struct ValClass;
            o Interfaces
            § interface class IType;
            § interface struct IType;
            o Enumerations
            § enum class Color;
            § enum struct Color;
            3、 Native types
            o class Native;
            o struct Native;
            示例:
            using namespace System;
            interface class IDog
            {
            void Bark();
            };
            ref class Dog : IDog
            {
            public:
            void Bark()
            {
            Console::WriteLine("Bow wow wow");
            }
            };
            void _tmain()
            {
            Dog^ d = gcnew Dog();
            d->Bark();
            }

上述程序中的代碼與老的C++語(yǔ)言相比看上去非常簡(jiǎn)潔,在以往的C++代碼中,至少要用到-gc和-interface這兩個(gè)關(guān)鍵詞。

九、裝箱/拆箱操作

在C++/CLI中,加箱是隱含的,而且類型是安全的,一個(gè)二進(jìn)制的拷貝被執(zhí)行并在CLR堆上形成一個(gè)對(duì)象,去箱是顯式的,僅僅需要使用reinterpret_cast操作符來(lái)解除引用。

void _tmain()
            {
            int z = 44;
            Object^ o = z; //implicit boxing
            int y = *reinterpret_cast<int^>(o); //unboxing
            Console::WriteLine("  ",o,z,y);
            z = 66;
            Console::WriteLine("  ",o,z,y);
            }
            // 輸出結(jié)果如下:
            // 44 44 44
            // 44 66 44

在上述代碼中,"o"對(duì)象是一個(gè)加箱的拷貝,從第二個(gè)語(yǔ)句Console::WriteLine.的輸出可以很明顯地看到,它并沒(méi)有涉及到int類型的整數(shù)值。

當(dāng)你對(duì)一種數(shù)值類型進(jìn)行加箱操作時(shí),返回的對(duì)象記住了最初的數(shù)值類型。

void _tmain()
            {
            int z = 44;
            float f = 33.567;
            Object^ o1 = z;
            Object^ o2 = f;
            Console::WriteLine(o1->GetType());
            Console::WriteLine(o2->GetType());
            }
            // Output
            // System.Int32
            // System.Single

因此不能對(duì)不同類型的對(duì)象進(jìn)行去箱操作。

void _tmain()
            {
            int z = 44;
            float f = 33.567;
            Object^ o1 = z;
            Object^ o2 = f;
            int y = *reinterpret_cast<int^>(o2);//System.InvalidCastException
            float g = *reinterpret_cast<float^>(o1);//System.InvalidCastException
            }

如果你非嘗試這么做,那么你將得到一個(gè)System.InvalidCastException。讓我們來(lái)探討一下完美的類型安全性,如果你要看內(nèi)部代碼,你將看到微軟的內(nèi)部箱在實(shí)際中的運(yùn)用。例如:

void Box2()
            {
            float y=45;
            Object^ o1 = y;
            }

編譯后的代碼是:

.maxstack 1
            .locals (float32 V_0, object V_1)
            ldnull
            stloc.1
            ldc.r4 45.
            stloc.0
            ldloc.0
            box [mscorlib]System.Single
            stloc.1
            ret

根據(jù)微軟的內(nèi)部文檔,箱操作將未加工的類型轉(zhuǎn)換為一個(gè)具體類型的實(shí)例,這項(xiàng)工作的完成通過(guò)創(chuàng)建一個(gè)新的對(duì)象并將數(shù)據(jù)拷貝到這個(gè)新分配的對(duì)象。

十、寫在后面的話

為什么很多人已經(jīng)可以使用C、C++、.NET來(lái)開(kāi)發(fā)程序但還在積極學(xué)習(xí)C++/CLI呢,我想有四個(gè)方面的原因:

1、從編譯器直到內(nèi)層都還在支持C++代碼;

2、C++/CLI對(duì)于其他標(biāo)準(zhǔn)來(lái)說(shuō)無(wú)意是具有毀滅性地;

3、與生俱來(lái)的內(nèi)部支持勝過(guò)所有其他CLI語(yǔ)言

4、所有在MFC中出現(xiàn)的下劃線都已不再存在。

posted on 2008-07-18 22:28 夢(mèng)在天涯 閱讀(6441) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Manage c++ /CLI

公告

EMail:itech001#126.com

導(dǎo)航

統(tǒng)計(jì)

  • 隨筆 - 461
  • 文章 - 4
  • 評(píng)論 - 746
  • 引用 - 0

常用鏈接

隨筆分類

隨筆檔案

收藏夾

Blogs

c#(csharp)

C++(cpp)

Enlish

Forums(bbs)

My self

Often go

Useful Webs

Xml/Uml/html

搜索

  •  

積分與排名

  • 積分 - 1814996
  • 排名 - 5

最新評(píng)論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              亚洲综合电影一区二区三区| 亚洲一区二区三区久久| 欧美成人69| 久久av最新网址| 午夜一区在线| 欧美一区二区三区免费在线看| 亚洲狠狠丁香婷婷综合久久久| 狠狠网亚洲精品| 一区二区亚洲精品国产| 亚洲国产精品va在线看黑人动漫| 黄色日韩网站视频| 激情av一区| 亚洲高清视频一区二区| 亚洲区一区二区三区| 亚洲精品免费一二三区| 日韩写真视频在线观看| 亚洲一区自拍| 久久国产精品99久久久久久老狼| 久久国产欧美精品| 欧美高清视频www夜色资源网| 欧美激情一区二区在线 | 亚洲免费影视| 欧美伊久线香蕉线新在线| 久久久久久夜| 亚洲国产高清在线| 99re在线精品| 香蕉成人久久| 欧美aaa级| 国产精品视频免费观看| 伊人夜夜躁av伊人久久| 国产精品99久久久久久久久久久久| 午夜亚洲福利| 欧美韩日一区二区三区| 久久嫩草精品久久久精品| 亚洲高清视频一区| 亚洲综合国产| 欧美高清成人| 国产在线精品自拍| 亚洲视频二区| 麻豆av一区二区三区久久| 亚洲久久一区二区| 亚洲视频在线免费观看| 国产精品大片免费观看| 国产精品丝袜白浆摸在线| 在线欧美亚洲| 欧美一级久久久| 亚洲国产精品一区二区三区| 亚洲欧美春色| 欧美日韩一区二区视频在线 | 久久香蕉国产线看观看av| 欧美激情第4页| 一区免费在线| 欧美亚洲在线播放| 日韩视频免费| 欧美大片网址| 亚洲国产精品va在看黑人| 欧美一区二区三区男人的天堂 | 国产精品综合久久久| 99精品国产在热久久| 亚洲欧美春色| 亚洲毛片网站| 欧美精品啪啪| 亚洲人成在线观看| 麻豆精品在线播放| 午夜久久久久久久久久一区二区| 欧美日韩高清区| 亚洲美女av黄| 亚洲国产精品一区制服丝袜| 久久视频这里只有精品| 韩国欧美国产1区| 久久精品91久久香蕉加勒比| 亚洲一区二区三区影院| 国产精品久久9| 亚洲尤物视频网| 一区二区免费在线播放| 欧美视频中文一区二区三区在线观看 | 欧美国产欧美综合| 亚洲欧洲午夜| 亚洲激情女人| 欧美日韩免费观看一区三区| 一区二区三区四区五区精品视频| 欧美.日韩.国产.一区.二区| 久久久91精品国产一区二区精品| 伊人成人开心激情综合网| 久久综合九色欧美综合狠狠| 久久人人97超碰国产公开结果| 激情久久婷婷| 宅男噜噜噜66国产日韩在线观看| 亚洲精品日韩在线| 国产精品青草久久| 久久综合给合久久狠狠狠97色69| 老司机67194精品线观看| 男女激情久久| 中文日韩电影网站| 亚洲一区二区精品| 国产欧美一区二区三区在线看蜜臀| 亚洲欧美偷拍卡通变态| 欧美一区二区精品在线| 亚洲国产精品一区二区第四页av| 亚洲大片免费看| 国产精品扒开腿做爽爽爽视频 | 欧美韩日一区二区| 这里只有视频精品| 欧美亚洲免费| 亚洲乱码国产乱码精品精| 在线性视频日韩欧美| 国产在线播放一区二区三区| 欧美国产三区| 欧美性猛交xxxx乱大交蜜桃| 久久久久国产精品一区| 欧美激情在线| 久久精品免费| 欧美日韩国产va另类| 久久国产精品色婷婷| 欧美国产丝袜视频| 久久精品一二三区| 欧美日韩免费一区二区三区| 久久久91精品国产| 欧美伦理91i| 久久精品视频在线播放| 欧美精品www| 老司机亚洲精品| 国产精品久久久久久久浪潮网站| 你懂的视频欧美| 国产美女在线精品免费观看| 亚洲国产日韩欧美在线图片| 国产在线观看精品一区二区三区| 99国产精品一区| 亚洲高清二区| 亚洲欧美一区二区三区极速播放| 日韩一级免费| 久久蜜桃精品| 久久精品综合| 在线成人中文字幕| 久久国产精品99精品国产| 欧美日韩精品免费观看视一区二区 | 欧美日韩国内自拍| 欧美国产日韩一区二区| 国产一区二区在线免费观看 | 亚洲靠逼com| 夜夜嗨av一区二区三区中文字幕| 免费91麻豆精品国产自产在线观看| 久久久精品免费视频| 国产欧美一二三区| 午夜精品视频在线观看一区二区| 性色一区二区| 国产欧美成人| 性xx色xx综合久久久xx| 欧美伊人久久久久久久久影院| 亚洲人成网站999久久久综合 | 欧美激情视频网站| 亚洲精品123区| 欧美激情在线观看| 亚洲免费激情| 亚洲欧美日韩综合| 国产精品成人观看视频免费| 亚洲最新视频在线| 亚洲欧美电影在线观看| 国产精品理论片在线观看| 亚洲一区视频在线观看视频| 欧美制服丝袜| 精品二区久久| 免费亚洲一区二区| 亚洲第一区中文99精品| 亚洲国产合集| 欧美片网站免费| 一本色道久久综合狠狠躁的推荐| 亚洲乱亚洲高清| 国产精品青草久久| 亚洲丝袜av一区| 亚洲欧美制服另类日韩| 极品尤物av久久免费看| 久久激情一区| 米奇777在线欧美播放| 有码中文亚洲精品| 欧美丝袜一区二区| 亚洲午夜精品| 久久久国产成人精品| 一区免费观看| 欧美三级午夜理伦三级中视频| 夜夜爽av福利精品导航| 亚洲欧美偷拍卡通变态| 久久人人97超碰精品888| avtt综合网| 亚洲免费高清视频| 国产精品久久国产精品99gif| 亚洲免费视频成人| 久久青青草原一区二区| 一片黄亚洲嫩模| 国产精品视频| 久久精品一二三| 久久精品一本| 亚洲欧美日韩在线观看a三区| 国产亚洲毛片在线| 美国三级日本三级久久99| 久久中文欧美| 亚洲欧美日韩国产一区二区三区| 国产有码在线一区二区视频| 你懂的视频一区二区| 欧美激情第9页|