2012-02-06 17 views
0

メイン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の

+1

呼び出し規約が一致していますか?私は動的にロードされた関数を介してポインタよりも複雑なものを決して渡すことはありません... – PlasmaHH

+0

私はPlasmaHHだ。動的リンクは、C++ ABI、テンプレートコード、例外などとうまく網羅できません。 – sehe

+0

答えは見つかりましたが、解決策は見つかりませんでした。 boost :: anyをコピーすると、dll内で実行される仮想メソッドclone()が呼び出され、新しいオブジェクトの仮想テーブルもdllに存在します。 – micdelt

答えて

1

これは実際anyが何であるかに依存します。たとえば、デストラクタを持つオブジェクトにはshared_ptrが、デストラクタコードはDLLに存在します。その後、DLLをアンロードする前に、すべてのインスタンスanyを破棄する必要があります。

0

nullポインタを処理しないメモリマネージャでも同じ問題がありました。