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

C++ Programmer's Cookbook

{C++ 基礎} {C++ 高級} {C#界面,C++核心算法} {設計模式} {C#基礎}

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

 

一、緒論

當微軟推出VS.NET7實現了可擴展的托管C++后,C++程序員們反映不一。盡管大部分的程序員對于能夠繼續使用C++感到很欣慰,但幾乎所有的人對于托管C++提供的晦澀語法感到很痛苦。微軟明顯從反饋中感覺到托管C++不是那么成功。

2003年10月6日,ECMA(歐洲計算機制造商協會)宣布成立專家組,負責結合ISO標準C++與通用語言,開發一個可擴展語言的標準,這個新的可擴展語言被稱為C++/CLI標準。這個標準將被VS.NET2005的C++編譯器支持。

二、老語法存在的問題

1、晦澀繁瑣的語法和文法--這兩個"雙重底線"問題加重了閱讀的負擔。

2、二流的CLI支持--相對與C#與VB.NET,MC++使用不方便的工作區來提供CLI支持,例如,它沒有一個一一對應的結構來列舉.NET的集合。

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

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

5、MFC編譯器不能產生可校驗的代碼。

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

1、優雅流暢的語法和文法--C++/CLI為C++開發人員書寫托管代碼提供了一種非常自然的感覺,并且它提供了非托管代碼到托管代碼的平滑過度。以前所謂的"雙重底線"問題現在已經蕩然無存。

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

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

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

5、C++/CLI編譯器產生的可執行文件完全是可校驗的。

四、"Hello World"小程序

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

上述代碼除了不需要引用mscorlib.dll庫外,與老的語法沒有太大的區別,因為無論你什么時候使用/clr進行編輯,編譯器都可以暗中進行引用(現在默認的是/clr:newSyntax)。

五、句柄

與老的語法主要的混淆是我們習慣于使用*符號來聲明拖管引用或非拖管指針,在C++/CLI里微軟引入了句柄的概念。

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

^符號代表一個托管對象(聲明時看上去象個帽子),按照CLI的規定,句柄代表一個拖管對象的引用。句柄在CLI中是新的語法,相當于C++中的-gc指針。句柄與指針不再混淆,在本質上兩者完全不同。

六、句柄與指針是怎樣區分開來的?

1、指針聲明時使用*符號,而句柄使用^符號。

2、句柄是針對拖管堆上對象的拖管引用,而指針僅僅指向內存中的一個地址。

3、指針很穩定,GC循環不會影響到它;句柄在基于GC或內存緊張的情況下,可以指向不同的內存位置。

4、對于指針,程序開發人員必須"顯式"地刪除,否則會面臨泄露的危險,而對于句柄,是否進行顯式刪除則完全根據程序人員的愛好了。

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

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

七、CLR對象示例

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

關鍵字gcnew用來實例化一個CLI對象,而且它返回一個指向在CLR堆上的對象的句柄,gcnew的優點在于它可以方便的讓我們區分拖管和非拖管的實例對象。

大部分情況下,gcnew關鍵字和^操作符提供了你用來進行BCL的一切手段,但是很明顯你需要創建和聲明屬于自己的拖管類和接口。

八、聲明類型

CLR類型有一個形容詞前綴用來說明類型的種類,下面是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++語言相比看上去非常簡潔,在以往的C++代碼中,至少要用到-gc和-interface這兩個關鍵詞。

九、裝箱/拆箱操作

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

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);
            }
            // 輸出結果如下:
            // 44 44 44
            // 44 66 44

在上述代碼中,"o"對象是一個加箱的拷貝,從第二個語句Console::WriteLine.的輸出可以很明顯地看到,它并沒有涉及到int類型的整數值。

當你對一種數值類型進行加箱操作時,返回的對象記住了最初的數值類型。

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

因此不能對不同類型的對象進行去箱操作。

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
            }

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

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

根據微軟的內部文檔,箱操作將未加工的類型轉換為一個具體類型的實例,這項工作的完成通過創建一個新的對象并將數據拷貝到這個新分配的對象。

十、寫在后面的話

為什么很多人已經可以使用C、C++、.NET來開發程序但還在積極學習C++/CLI呢,我想有四個方面的原因:

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

2、C++/CLI對于其他標準來說無意是具有毀滅性地;

3、與生俱來的內部支持勝過所有其他CLI語言

4、所有在MFC中出現的下劃線都已不再存在。

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

公告

EMail:itech001#126.com

導航

統計

  • 隨筆 - 461
  • 文章 - 4
  • 評論 - 746
  • 引用 - 0

常用鏈接

隨筆分類

隨筆檔案

收藏夾

Blogs

c#(csharp)

C++(cpp)

Enlish

Forums(bbs)

My self

Often go

Useful Webs

Xml/Uml/html

搜索

  •  

積分與排名

  • 積分 - 1814987
  • 排名 - 5

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              欧美午夜视频网站| 亚洲黄色有码视频| 久久精品道一区二区三区| 亚洲乱码国产乱码精品精98午夜| 久久精品国产清高在天天线| 亚洲午夜精品福利| 亚洲午夜国产一区99re久久| 99精品热视频| 亚洲嫩草精品久久| 欧美一区二区三区免费看 | 久久综合五月| 另类亚洲自拍| 欧美高清视频一区二区| 麻豆91精品| 久久国产精品久久w女人spa| 亚洲欧美日韩一区二区三区在线| 久久精品观看| 免费不卡亚洲欧美| 欧美韩日精品| 国产精品www色诱视频| 国产九九视频一区二区三区| 午夜精品福利一区二区三区av| 亚洲欧美日韩综合国产aⅴ| 久久激情视频久久| 欧美日韩国产黄| 国产精品久久久久久模特| 国产欧美日韩三区| 91久久国产综合久久| 一区电影在线观看| 欧美一区二区性| 蜜桃久久精品乱码一区二区| 日韩一二在线观看| 性久久久久久久久久久久| 久久国产精品一区二区| 免费日韩一区二区| 国产精品丝袜xxxxxxx| 亚洲国产精品成人久久综合一区 | 可以看av的网站久久看| 91久久午夜| 亚洲精品国产日韩| 久久激情网站| 国产精品国产三级国产a| 在线播放国产一区中文字幕剧情欧美 | 亚洲综合国产| 欧美不卡在线视频| 国产伦精品一区二区三区四区免费| 国产一区二区三区无遮挡| 91久久黄色| 久久久国产精品一区| 亚洲精品欧美激情| 久久久噜噜噜久久中文字幕色伊伊| 欧美日韩不卡| 亚洲电影观看| 久久久777| 亚洲自拍三区| 欧美国产国产综合| 国产一区二区三区丝袜| 亚洲男人天堂2024| 亚洲欧洲日本在线| 日韩视频―中文字幕| 精品电影一区| 欧美一级久久久| 一本到12不卡视频在线dvd| 欧美黑人多人双交| 伊人久久大香线蕉综合热线 | 亚洲欧美卡通另类91av| 欧美日韩国产综合新一区| 在线免费观看日本欧美| 麻豆久久久9性大片| 欧美一区二区三区四区视频| 国产精品国产a级| 亚洲欧洲综合另类在线| 另类激情亚洲| 欧美自拍偷拍午夜视频| 国产视频综合在线| 久久精品论坛| 亚洲精品网址在线观看| 欧美成人午夜| 一区二区三区回区在观看免费视频| 亚洲成色999久久网站| 免费视频一区二区三区在线观看| 狠狠色香婷婷久久亚洲精品| 久久久久成人精品免费播放动漫| 午夜国产精品视频| 国产精品九九久久久久久久| 亚洲高清一二三区| 91久久极品少妇xxxxⅹ软件| 美女啪啪无遮挡免费久久网站| 亚洲日本中文字幕| 日韩一级大片| 国产精品视频一二| 久久亚洲一区二区三区四区| 久久精品99国产精品| 亚洲国产电影| 亚洲美洲欧洲综合国产一区| 欧美午夜精品电影| 性做久久久久久久久| 欧美伊人久久久久久午夜久久久久| 国产伦精品一区二区三区视频孕妇 | 亚洲高清毛片| 欧美日韩国产系列| 欧美在现视频| 欧美成人69av| 亚洲欧美文学| 免费高清在线一区| 午夜精品三级视频福利| 欧美一二区视频| 亚洲国产另类精品专区| 亚洲精品专区| 亚洲福利视频在线| 亚洲视屏在线播放| 久久人人爽人人| 鲁大师影院一区二区三区| 亚洲国产高清高潮精品美女| 亚洲精品一区久久久久久| 国产偷国产偷精品高清尤物| 亚洲成在人线av| 国产精品久久久久久久第一福利| 美女主播一区| 99re8这里有精品热视频免费| 国产日韩成人精品| 日韩视频中文字幕| 亚洲第一精品电影| 亚洲欧美视频一区| 99人久久精品视频最新地址| 午夜影院日韩| 亚洲影视九九影院在线观看| 欧美亚洲专区| 亚洲综合三区| 欧美电影免费观看网站| 久久av一区二区三区漫画| 欧美日韩国产一区| 欧美成人一二三| 国产欧美一区二区三区在线老狼 | 性欧美办公室18xxxxhd| 亚洲深夜av| 欧美成人激情视频| 美女视频黄a大片欧美| 国产欧美视频一区二区三区| 亚洲精品美女| 一区二区电影免费观看| 老司机精品视频网站| 久久久久青草大香线综合精品| 欧美日韩精品福利| 亚洲国产天堂久久综合网| 亚洲第一区中文99精品| 久久国产一区二区| 欧美一区二区在线播放| 国产精品国产亚洲精品看不卡15 | 欧美激情二区三区| 亚洲国产精品久久久久秋霞不卡| 国产自产高清不卡| 欧美韩日精品| 亚洲第一中文字幕在线观看| 久久国产精品99精品国产| 久久电影一区| 精品电影一区| 欧美激情综合色综合啪啪| 欧美国产日韩xxxxx| 最新国产乱人伦偷精品免费网站| 美国十次成人| 亚洲欧洲在线看| 欧美国内亚洲| 日韩一级精品| 欧美一区二区观看视频| 国产一区二区精品久久91| 久久久国产亚洲精品| 欧美激情久久久| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美日本一道本在线视频| 伊人久久久大香线蕉综合直播| 久久av资源网| 国产综合自拍| 欧美电影免费网站| 亚洲特级片在线| 久久久精彩视频| 亚洲精品国产精品国自产观看 | 亚洲国产婷婷综合在线精品| 亚洲图色在线| 国产一区二区三区奇米久涩| 久久手机精品视频| 99视频国产精品免费观看| 欧美一区二区三区视频在线观看| 精品91免费| 欧美日韩亚洲综合一区| 久久精品国产综合精品| 亚洲伦理久久| 国产精品影院在线观看| 久久久综合视频| 中国av一区| 欧美激情小视频| 亚洲欧美精品伊人久久| 永久免费视频成人| 欧美日韩亚洲视频一区| 欧美影视一区| 亚洲美女尤物影院| 麻豆精品精华液| 亚洲欧美日韩综合一区| 亚洲欧洲一区二区三区在线观看| 国产精品久久久久久av下载红粉|