我已经声明了一个类并实例化了一个类,并期望它会触发
~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)
上创建它,则当对象超出范围时将调用析构函数。