C#调用C/C++的dll有两种方式,下边就写一下两种不同方式的调用方法。
1.DllImport方式
[DllImport("CalcDll")]
public extern int Add(int a, int b);
其中CalcDll为C++动态库,Add为动态库中的方法,使用DllImport引入需要加载的DLL,使用关键字extern修饰C++库中的方法,之后正常调用即可。
2.动态加载
1.首先引入以下三个方法
[DllImport("kernel32.dll", CallingConvention = CallingConvention.StdCall)]
private static extern IntPtr LoadLibrary(string lpFileName, int h, int flags);
[DllImport("kernel32.dll", CharSet = CharSet.Ansi, ExactSpelling = true, SetLastError = true)]
private static extern IntPtr GetProcAddress(IntPtr hModule, string lProcName);
[DllImport("kernel32.dll", CallingConvention = CallingConvention.StdCall)]
private static extern bool FreeLibrary(IntPtr hModule);
2.加载DLL
IntPtr m_hModule = LoadLibrary(@"D:\CalcDll.dll", 0, (int)LoaderOptimization.MultiDomain);
其中dll路径必须是全路径。
3.定义方法的委托
private delegate int Delegate_Add(int x,int y);
private Delegate_Add m_Delegate_Add;
4.动态获取该函数的委托方法对象
IntPtr func = GetProcAddress(m_hModule, “Add”);
Type t=typeof(Delegate_Add);
m_Delegate_Add=(Delegate)Marshal.GetDelegateForFunctionPointer(func, t);
其中“Add”为C++动态库中的函数名。
5.调用委托方法
int sum=m_Delegate_Add(2,3);
注意使用完之后加入析构函数,一定要释放m_hModule
~CDriver() { FreeLibrary(m_hModule); }
原文链接:https://blog.csdn.net/jh_negit/article/details/117446570