關(guān)于C#調(diào)用C++dll傳指針釋放內(nèi)存問題
一、傳入dll前,在C#中申請內(nèi)存空間
c#里面的指針即 IntPtr
申請如下:
IntPtr SrcImgData = Marshal.AllocHGlobal(length);
這種需要提前知道空間大小,否則無法確定空間大小,會導(dǎo)致dll內(nèi)部處理時越界報錯。
c#里面申請空間了,那么c++里面一般就是在這些空間里面操作了,一般不會重新分配內(nèi)存,那么就不需要加引用了。
c++:
uchar* SrcImg
c#導(dǎo)入dll函數(shù)時申明:
IntPtr SrcImg
那么內(nèi)存釋放自然也是由c#來進行。
Marshal.FreeHGlobal(SrcImgData);
二、dll內(nèi)部會對指針重新分配內(nèi)存
這時c#便不需要在外部申請內(nèi)存空間,初始化一個指針即可:
IntPtr SrcImg = IntPtr.Zero;
由于dll內(nèi)部申請了空間,作出了一些改變,所以想要傳回C#中需要使用引用
c++:
uchar* &SrcImg
c#導(dǎo)入dll函數(shù)時申明:
ref IntPtr SrcImg
C++內(nèi)部申請內(nèi)存空間有幾種方式,new或者malloc,如果是這兩種分配方式,那么dll應(yīng)該提供釋放內(nèi)存的函數(shù)接口,否則C#無法正常釋放內(nèi)存,長時間運行內(nèi)存會逐漸增長即內(nèi)存泄漏。
如果是通過cotaskmemalloc方式申請內(nèi)存:
SrcImg = (uchar*)CoTaskMemAlloc(length);
那么C#里面可以正常釋放:
Marshal.FreeHGlobal(SrcImg);
當(dāng)然,如果C++中提供釋放接口的話就不需要這樣去釋放了。
三、clr模式下的C++dll
經(jīng)過測試,如果用clr,C++內(nèi)部用new來分配內(nèi)存,C#里面可以通過FreeHGlobal正常釋放
到此這篇關(guān)于關(guān)于C#調(diào)用C++dll傳指針釋放內(nèi)存問題的文章就介紹到這了,更多相關(guān)c#調(diào)用c++dll釋放內(nèi)存內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C#調(diào)用C++dll方法步驟
- C#通過PInvoke調(diào)用c++函數(shù)的備忘錄的實例詳解
- vs2019 實現(xiàn)C#調(diào)用c++的dll兩種方法
- C#調(diào)用C++動態(tài)庫接口函數(shù)和回調(diào)函數(shù)方法
- c#調(diào)用c++的DLL的實現(xiàn)方法
- C#調(diào)用C++的dll兩種實現(xiàn)方式(托管與非托管)
- C#程序調(diào)用C++動態(tài)庫(dll文件)遇到的坑及解決
- 在C#項目中調(diào)用C++編寫的動態(tài)庫的三種方式
- C#調(diào)用C++使用C++/CLI的實現(xiàn)
相關(guān)文章
C#中Array與ArrayList用法及轉(zhuǎn)換的方法
C#中Array與ArrayList用法及轉(zhuǎn)換的方法,需要的朋友可以參考一下2013-03-03C#循環(huán)與循環(huán)控制的表達式樹實現(xiàn)
這篇文章介紹了C#循環(huán)與循環(huán)控制的表達式樹實現(xiàn),文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-01-01