我已经声明了一个类并实例化了一个类,并期望它会触发

~CLog();


但是由于某种原因,事实并非如此。有人看到为什么会发生这种错误吗?

我在一个空虚的地方声明了该类,所以我认为它应该触发。
我没有明确地销毁该类,但我只是希望它会自动超出范围并终止。

#pragma once
#include <fstream>
using namespace std;

class CLog
{
  public:
    CLog(wstring filename);
    ~CLog();
    void WriteString(wstring uString);
  private:
    wofstream m_stream;
    wstring m_sPath;
};

#include "log.h";
#include "strhelper.h"

#include <fstream>
#include <iostream>
#include <string>
#include <locale>
#include <codecvt>

wstring m_sText=L"";
wstring m_sPath=L"";

CLog::CLog(wstring uPath)
{
    m_sPath=uPath;
}
void CLog::WriteString(wstring uString)
{
    m_sText+=uString;
    m_sText+=L"\n";
}
CLog::~CLog()
{

    if (FileExists(m_sPath))
    {
        DeleteFile(m_sPath);
    }

    //open for appending
    m_stream.imbue(std::locale(std::locale::empty(), new std::codecvt_utf8<wchar_t,0x10ffff,std::generate_header>));
    m_stream.open(m_sPath,fstream::in | fstream::out | fstream::app);

    m_stream << m_sText.c_str();

    m_stream.close();
}


我正在这样使用Clog

void foo() {
  wstring sLogPath;
  sLogPath=GetSpecialFolderDesktop() + L"\\load.log";
  CLog *pLog = new CLog(sLogPath);
  pLog->WriteString(L"Something);
}


我正在使用VC2010。

最佳答案

您正在动态实例化CLog。在这种情况下,您需要明确删除它。
如果在堆栈Clog log(sLogPath)上创建它,则当对象超出范围时将调用析构函数。

07-24 09:37