Вызов между управляемым и неуправляемым кодом через обратный вызов
Я столкнулся с большой проблемой при передаче строки между управляемым и неуправляемым кодом. После поиска и объединения кодов у меня есть решение, которое, кажется, работает. Но все же я не уверен, что это правильная реализация.
В моем коде C# передает функцию делегата в C++. Теперь C++ вызывает эту функцию всякий раз, когда требуется. C++ должен отправить строку для вызова функции, для которой я использую BSTR. Вот как я это реализовал.
C#
[DllImport("xyz.dll")]
public static extern void SetCallback(Callback fn);
public delegate void Callback([MarshalAs(UnmanagedType.BStr)]string str);
public Callback mInstance;
private void Handler(string text)
{
NotifyListeners_uccx(text);
}
Private void setcallback(){
mInstance = new Callback(Handler);
SetCallback(mInstance); }
C++
typedef void (__stdcall *Callback) (BSTR str);
Callback Handler;
extern "C"
{
void __declspec(dllexport) __stdcall SetCallback(Callback handler);
void __declspec(dllexport) __stdcall SendReceiveMessage(BSTR arr1);
}
void __stdcall SendReceiveMessage(BSTR arr1) {
Handler(arr1);
}
void __stdcall SetCallback(Callback handler1) {
Handler = handler1;
}
void CCall::sendmsg(FILE *fp)
{
//do some work
try
{
char *str;
char *Tag_t;
str = new char[2048];
Tag_t = new char[1024];
sprintf(str, "<body><Tag1>%d</Tag1 ><Tag2>%s</Tag2>",sumNum, SumString);
for (int i = 0; i < sumNum; i++)
{
sprintf(Tag_t,"<Tag3>%s</Tag3>",tagString3,m_csqIDs[i],i);
strcat(str,Tag_t);
}
strcat(str,"</body>");
int wslen = MultiByteToWideChar(CP_ACP, 0, str, strlen(str), 0, 0);
BSTR bstr = SysAllocStringLen(0, wslen);
MultiByteToWideChar(CP_ACP, 0, str, strlen(str), bstr, wslen);
// Use bstr here
SendReceiveMessage(bstr);
SysFreeString(bstr);
//SysFreeString(bstr);
delete[] str;
delete[] Tag_t;
}
catch(std::bad_alloc& exc)
{
return;
}
}
Пожалуйста, предложите, если это правильный способ сделать это?