你好,我有一个DLL文件需要调用其中的一个函数。该函数的签名如下:
const char* callMethod(const char* key, const char* inParams);
如果我使用 Ruby,一切正常:
attach_function :callMethod, [:string, :string], :string
如果我使用C++或C#,我会遇到堆栈溢出的问题!?
C#:
[DllImport("DeviceHub.dll", CallingConvention = CallingConvention.Cdecl)]
private unsafe static extern IntPtr callMethod(
[MarshalAs(UnmanagedType.LPArray)] byte[] key,
[MarshalAs(UnmanagedType.LPArray)] byte[] inParams
);
System.Text.UTF8Encoding encoding = new UTF8Encoding();
IntPtr p = callMethod(encoding.GetBytes(key), encoding.GetBytes(args)); // <- stack overflow here
c++:
extern "C"
{
typedef DllImport const char* ( *pICFUNC) (const char*, const char*);
}
HINSTANCE hGetProcIDDLL = LoadLibrary(TEXT("C:\\JOAO\\Temp\\testedll\\Debug\\DeviceHub.dll"));
FARPROC lpfnGetProcessID = GetProcAddress(HMODULE (hGetProcIDDLL),"callMethod");* pICFUNC callMethod;
callMethod = (pICFUNC) lpfnGetProcessID;
const char * ptr = callMethod("c", "{}");
我尝试了很多调用函数的方式: WINAPI、PASCAL、stdcall、fastcall等,但都没有成功。
这个DLL不是我制作的,我无法控制它。
有没有人能给我任何建议呢?
string
作为这两个参数的类型? - Ove