0

VC Express 2008 でLoki::SingletonLoki::SmartPtr、およびstd::vectorを使用しているときに問題が発生しました 。以下は私のソースです。

#include <iostream>
#include <vector>
#include <loki/Singleton.h>
#include <loki/SmartPtr.h>

class Foo {
  public:
    std::vector<Loki::SmartPtr<Foo>> children ;
    void add() {
        Loki::SmartPtr<Foo> f = new Foo ;
        children.push_back(f) ;
    }
    Foo () {
    }
    ~Foo () {
    }
} ;

typedef Loki::SingletonHolder<Foo> SingletonFoo ;

int main ()
{
    std::cout << "Start" << std::endl ;
    SingletonFoo::Instance().add() ;
    std::cout << "End" << std::endl ;
}

コンパイルとリンクは問題ありませんが、プログラムの終了後にエラーが表示されます。

Windows has triggered a breakpoint in test.exe.
This may be due to a corruption of the heap, which indicates a bug in test.exe or any of the DLLs it has loaded.
This may also be due to the user pressing F12 while test.exe has focus.
The output window may have more diagnostic information.

一部のメモリが2回削除されているようですが、よくわかりません。それは VC のバグですか、それとも使用済みの Loki が恋しいですか?

前もって感謝します。

4

3 に答える 3

1

IMR、stlコンテナで特定のスマートポインタを使用することはできません。これが発生する正確な問題です。メモリが機能する場合、それは、stlコンテナがスマートポインタの使用方法に準拠していない値をコピーする方法と関係があります。

于 2009-07-07T19:55:19.500 に答える
1

VC を使用しているため、デバッグ モードでコードを実行し、stp (F10、F11) ごとにコードを実行して、コードが壊れている場所を確認できるはずです。

とにかく、Loki シングルトン コードを見ると、エラーは SingletonHolder::DestroySingleton() のアサートから来ているようです:

 SingletonHolder<T, CreationPolicy, L, M, X>::DestroySingleton()
00837     {
00838         assert(!destroyed_); // there, but it's a wild guess
00839         CreationPolicy<T>::Destroy(pInstance_);
00840         pInstance_ = 0;
00841         destroyed_ = true;
00842     }

このコードが示唆するように、その関数はLifetimePolicy(ここではDefaultLifetime)によって呼び出されるようです:

00800     template
00801     <
00802         class T,
00803         template <class> class CreationPolicy,
00804         template <class> class LifetimePolicy,
00805         template <class, class> class ThreadingModel,
00806         class MutexPolicy
00807     >
00808     void SingletonHolder<T, CreationPolicy, 
00809         LifetimePolicy, ThreadingModel, MutexPolicy>::MakeInstance()
00810     {
00811         typename ThreadingModel<SingletonHolder,MutexPolicy>::Lock guard;
00812         (void)guard;
00813         
00814         if (!pInstance_)
00815         {
00816             if (destroyed_)
00817             {
00818                 destroyed_ = false;
00819                 LifetimePolicy<T>::OnDeadReference();
00820             }
00821             pInstance_ = CreationPolicy<T>::Create();
00822             LifetimePolicy<T>::ScheduleDestruction(pInstance_, // here
00823                 &DestroySingleton);
00824         }
00825     }

なぜ2回呼び出されるのかはわかりませんが、SingletonHolderインスタンスの破棄時にシングルトンへのポインターが最初に破棄され(インスタンスではなくポインター)、次にLifetimePolicyがDestroySingleton()関数を呼び出そうとすると思います...

しかし、私は間違っているかもしれません。あなたはそれを確認する必要があります。

于 2009-07-07T19:40:16.300 に答える