handle---------IntPtr hwnd-----------IntPtr char *----------string int * -----------ref int int &-----------ref int void *----------IntPtr unsigned char *-----ref byte Struct需要在C#里重新定义一个Struct CallBack回调函数需要封装在一个委托里,delegate static extern int FunCallBack(string str); 注意在每个函数的前面加上public static extern +返回的数据类型,如果不加public ,函数默认为私有函数,调用就会出错。
我们可以通过下表来进行这种转换: Win32 Types CLR Type 现在,我们再来考虑下一个问题,如果要调用的函数参数是指针或是地址变量,怎么办? 对于这种情况可以使用C#提供的非安全代码来进行解决,但是,毕竟是非托管代码,垃圾资源处理不好的话对应用程序是很不利的。所以还是使用C#提供的ref以及out修饰字比较好。 同上面一样,我们也举一个例子:int __stdcall FunctionName(unsigned char ¶m1, unsigned char *param2) 在C#中对其进行调用的方法是:[DllImport(“ file ”)]extern static int FunctionName(ref byte param1, ref byte param2) 看到这,可能有人会问,&是取地址,*是传送指针,为何都只用ref就可以了呢?一种可能的解释是ref是一个具有重载特性的修饰符,会自动识别是取地址还是传送指针。 在实际的情况中,我们利用参数传递地址更多还是用在传送数组首地址上。如:byte[] param1 = new param1(6); 在这里我们声明了一个数组,现在要将其的首地址传送过去,只要将param1数组的第一个元素用ref修饰。具体如下:[DllImport(“ file ”)]extern static int FunctionName(ref byte param1[1], ref byte param2)
附:C++ 输入输出 C# ================================== char chr[255] O StringBuilder KCA_DIR I int LPCSTR I string int I int LPSTR O StringBuilder int* O out int DWORD I int DWORD* O out int BOOL I bool Rc_DBMgr I IntPtr long* O out long |