メインEXEはdllをロードします。単純なboost :: anyを返すdll関数を呼び出します。 boost :: anyが、FreeLibraryアプリがデストラクタでクラッシュした後に削除された場合。大丈夫です。しかし、私はこのコードがr2デストラクタでもクラッシュする理由を理解できません。r2はmainで作成し、deleteはdllコードを必要としません。 FreeLibraryの後にboost :: anyを保存するにはどうすればいいですか? extern "C"なしで試してみましょう - 同じ効果。boost ::任意のデストラクタクラッシュ
コンソールコード:
int _tmain(int argc, _TCHAR* argv[])
{
any r2;
HMODULE hmod = LoadLibrary(L"dll");
typedef any (*dllfunc)(int,int,int);
dllfunc func = (dllfunc) GetProcAddress(hmod,"Export1");
{
any r = func(1,2,3);
r2 = r;
}
FreeLibrary(hmod);
return 0;
}
DLLコード:
extern "C"
{
DLL_API any Export1(int a,int b, int c)
{
return a+b+c;
}
}
コンパイラVisual Studio 2005の
呼び出し規約が一致していますか?私は動的にロードされた関数を介してポインタよりも複雑なものを決して渡すことはありません... – PlasmaHH
私はPlasmaHHだ。動的リンクは、C++ ABI、テンプレートコード、例外などとうまく網羅できません。 – sehe
答えは見つかりましたが、解決策は見つかりませんでした。 boost :: anyをコピーすると、dll内で実行される仮想メソッドclone()が呼び出され、新しいオブジェクトの仮想テーブルもdllに存在します。 – micdelt