1

好吧,我的问题是,在我想“卸载”加载的 DLL 之后,复制分配运算符被无限次调用,直到崩溃。

我从中删除矢量数据的代码如下所示:

void UnloadPlugins()
{
    dbg(("[DBG]UnloadPlugins()"));
    for(std::vector<DLLInfo>::iterator it = plugins.begin(); it != plugins.end(); ++it) 
    {
        plugins.erase(it);
    }
    dbg(("[DBG]UnloadPlugins()::Done"));
}

但是“[DBG]UnloadPlugins()::Done”永远不会被打印出来。

这是我的复制分配运算符:

// 2. copy assignment operator
DLLInfo& operator=(const DLLInfo& that)
{
    dbg(("[DBG]Start-DLLInfo& operator=(const DLLInfo& that)"));
    Instance = that.Instance;//hinstance
    dbg(("[DBG]DLLInfo 1"));
    //Identifier.assign(that.Identifier);//string
    dbg(("[DBG]DLLInfo 2"));
    IsAMX = that.IsAMX;//integer
    dbg(("[DBG]DLLInfo 3"));
    dwSupportFlags = that.dwSupportFlags;//integer
    dbg(("[DBG]DLLInfo 4"));
    Load = that.Load;//integer
    dbg(("[DBG]DLLInfo 5"));
    Unload = that.Unload;//integer
    dbg(("[DBG]DLLInfo 6"));
    Supports = that.Supports;//integer
    dbg(("[DBG]DLLInfo 7"));
    ProcessTick = that.ProcessTick;//integer
    dbg(("[DBG]DLLInfo 8"));
    AmxLoad = that.AmxLoad;//integer
    dbg(("[DBG]DLLInfo 9"));
    AmxUnload = that.AmxUnload;//integer
    dbg(("[DBG]DLLInfo 10"));
    UseDestructor = that.UseDestructor;//bool
    dbg(("[DBG]DLLInfo 11"));
    KeyboardHit = that.KeyboardHit;//integer
    dbg(("[DBG]End-DLLInfo& operator=(const DLLInfo& that)"));
    return *this;
}

所以日志看起来像:

[17:50:50] [DBG]UnloadPlugins()
[17:50:50] [DBG]~DLLInfo    
[17:50:50] [DBG]~DLLInfo::if(this->UseDestructor) passed    
[17:50:50] [DBG]~DLLInfo::if(this->UseDestructor)::if(this->Unload != NULL && this->IsAMX) passed    
[17:50:50] [DBG]~DLLInfo::end    
[17:50:50] [DBG]Start-DLLInfo& operator=(const DLLInfo& that)    
[17:50:50] [DBG]DLLInfo 1   
[17:50:50] [DBG]DLLInfo 2    
[17:50:50] [DBG]DLLInfo 3    
[17:50:50] [DBG]DLLInfo 4    
[17:50:50] [DBG]DLLInfo 5    
[17:50:50] [DBG]DLLInfo 6    
[17:50:50] [DBG]DLLInfo 7    
[17:50:50] [DBG]DLLInfo 8    
[17:50:50] [DBG]DLLInfo 9    
[17:50:50] [DBG]DLLInfo 10    
[17:50:50] [DBG]DLLInfo 11    
[17:50:50] [DBG]End-DLLInfo& operator=(const DLLInfo& that)    
[17:50:50] [DBG]Start-DLLInfo& operator=(const DLLInfo& that)    
...  
[17:50:50] [DBG]End-DLLInfo& operator=(const DLLInfo& that)
...repeat until crash

问题可能是什么?

4

1 回答 1

1

erase返回一个迭代器(此处的文档),而不是++it在您的 for 中,您应该尝试it = plugins.erase(it);

但是看到你的代码,如果你只做erase所有事情,你最好打电话clear这里的文档)

于 2012-12-15T17:06:54.147 回答