C++/CLI思辨录之传递托管堆地址
生活随笔
收集整理的這篇文章主要介紹了
C++/CLI思辨录之传递托管堆地址
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
新的C++特點平衡了把托管堆的地址傳遞到非托管代碼的能力。早期我們遇到的最大問題是,在托管堆中的對象的位置是非靜態的。垃圾收集器以變化的時間間隔移動對象。現在新的pin_ptr(別針型指針)的引入禁止垃圾收集器改變在堆上的對象的地址。
下面代碼展示了別針型指針的應用。
基于輪廓的優化(Profile Guided Optimization)
在新版本的托管C++中有一項新增功能稱為基于輪廓的優化。這一新的編譯特點能夠實現在編譯時刻把探針注入到代碼中。最后的exe文件與一個數據庫一起打包發送,由該庫記錄下注入代碼中的探針監測到的結果數據。當用戶運行該程序時,這些探針記錄下應用程序的使用。當你下一次再編譯時,編譯器作出智能性決策,如根據探針的記錄作為相應的動作。這一特性帶來了真實世界的優化。
為什么沒有為使用托管類型而定義頭文件?
在傳統的C++中,一個頭文件一般包含對象的接口,或者類與函數的聲明,等等。這允許在多個翻譯單元上實現某種類型的一致性聲明。對于一個用托管代碼編 寫的且其被編譯成MSIL的對象,需要在配件集中包含描述對象的元數據。因而,托管C++編譯器不是通過頭文件,而是通過使用配件集元數據來實現接口的讀 取。這就是為什么你不必因使用托管類型而包含頭文件。事實上,你可以通過使用#using指令來讓編譯器從配件集中讀取元數據。
下面代碼展示了別針型指針的應用。
| #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指令來讓編譯器從配件集中讀取元數據。
總結
以上是生活随笔為你收集整理的C++/CLI思辨录之传递托管堆地址的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 在ASP.NET使用javascript
- 下一篇: 北京地区的网络人口调查