C++/CLI思辨錄之傳遞托管堆地址
新的C++特點平衡了把托管堆的地址傳遞到非托管代碼的能力。早期我們遇到的最大問題是,在托管堆中的對象的位置是非靜態的。垃圾收集器以變化的時間間隔移動對象?,F在新的pin_ptr(別針型指針)的引入禁止垃圾收集器改變在堆上的對象的地址。 下面代碼展示了別
新的
C++特點平衡了把托管堆的地址傳遞到非托管代碼的能力。早期我們遇到的最大問題是,在托管堆中的對象的位置是非靜態的。垃圾收集器以變化的時間間隔移動對象?,F在新的pin_ptr(別針型指針)的引入禁止垃圾收集器改變在堆上的對象的地址。
下面代碼展示了別針型指針的應用。
clearcase/" target="_blank" >cccccc" width="90%" align="center" bgcolor="#e3e3e3" border="1">
#pragma unmanaged
//本機函數,以整型指針作參數,執行計算
void calc(int* val)
{
//執行計算操作
}
#pragma managed
//托管函數調用本機calc函數
int managedfunc()
{
int i=gcnew int(10);
//把i的地址設置為別針型,以阻止對i的移動
pin_ptr<int> ppi=&i;
int* np=ppi;
calc(np);//用別針型int的地址調用本機函數
//把別針型指針的值置為nullptr,脫離了gc的限制
ppi=nullptr;
//完成剩下的工作
return i;
} |
基于輪廓的優化(Profile Guided Optimization)
在新版本的托管C++中有一項新增功能稱為基于輪廓的優化。這一新的編譯特點能夠實現在編譯時刻把探針注入到代碼中。最后的exe文件與一個
數據庫一起打包發送,由該庫記錄下注入代碼中的探針監測到的結果數據。當用戶運行該程序時,這些探針記錄下應用程序的使用。當你下一次再編譯時,編譯器作出智能性決策,如根據探針的記錄作為相應的動作。這一特性帶來了真實世界的優化。
為什么沒有為使用托管類型而定義頭文件?
在傳統的C++中,一個頭文件一般包含對象的接口,或者類與函數的聲明,等等。這允許在多個翻譯單元上實現某種類型的一致性聲明。對于一個用托管代碼編寫的且其被編譯成MSIL的對象,需要在配件集中包含描述對象的元數據。因而,托管C++編譯器不是通過頭文件,而是通過使用配件集元數據來實現接口的讀取。這就是為什么你不必因使用托管類型而包含頭文件。事實上,你可以通過使用#using指令來讓編譯器從配件集中讀取元數據。
原文轉自:http://www.kjueaiud.com
- 評論列表(網友評論僅供網友表達個人看法,并不表明本站同意其觀點或證實其描述)
-
老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月
|