jxlpxcj 发表于 2017-9-2 11:21:37

c++一个奇怪的问题

最近看小甲鱼C++学习视频自已学着写了一个记录LOG的一个类

#include <iostream>
#include <fstream>
#include <string>
#include <windows.h>
#include <stdio.h>

class FLOG
{
public:
        FLOG();                                    //类的构造函数
        ~FLOG();                                                                        //类的析构函数       
        BOOL write(std::string data);                                //写入函数
        BOOL write(std::string data, std::string data1); //写入函数的重载
        BOOL write(std::string data, std::string data1, std::string data2); //写入函数的重载

private:
        SYSTEMTIME time;
        std::ofstream out;
        char *filename;
        char *buff;
        BOOL rejet;
};

FLOG::FLOG()
{
        GetLocalTime(&time); //获取当前时间
        filename = new char;
        buff = new char;
        sprintf_s(filename, 200, "%d-%d-%d.log", time.wYear, time.wMonth, time.wDay);//格式化时间字符串
        out.open(filename, std::ios::app);//以当前时间为名打开一个LOG文件

        if (out.is_open())   //如果文件打开成功,设置REJET为真,否则为假
        {
                rejet = TRUE;
        }
        else
        {
                rejet = FALSE;
        }
}

FLOG::~FLOG()
{
        delete(filename);//释放FILENAME
        delete(buff);      //释放BUFF
        out.close();                //关闭文件句柄
}

BOOL FLOG::write(std::string data)
{
        if (rejet)      //如果REJET为真 则写入数据到文件
        {
                int i;
                GetLocalTime(&time);
                i = sprintf_s(buff, 200, "%d-%d-%d %d:%d:%d\t", time.wYear, time.wMonth, time.wDay, time.wHour, time.wMinute, time.wSecond);
                out.write(buff, i);
                out.write(data.c_str(), data.length());
                return TRUE;
        }
        else
        {
                return FALSE;
        }




}

BOOL FLOG::write(std::string data, std::string data1)
{
        if (rejet)
        {
                int i;
                GetLocalTime(&time);
                i = sprintf_s(buff, 200, "%d-%d-%d %d:%d:%d\t", time.wYear, time.wMonth, time.wDay, time.wHour, time.wMinute, time.wSecond);
                out.write(buff, i);
                out.write(data.c_str(), data.length());
                out.write(data1.c_str(), data1.length());
                return TRUE;
        }
        else
        {
                return FALSE;
        }

}

BOOL FLOG::write(std::string data, std::string data1, std::string data2)
{
        if (rejet)
        {
                int i;
                GetLocalTime(&time);
                i = sprintf_s(buff, 200, "%d-%d-%d %d:%d:%d\t", time.wYear, time.wMonth, time.wDay, time.wHour, time.wMinute, time.wSecond);
                out.write(buff, i);
                out.write(data.c_str(), data.length());
                out.write(data1.c_str(), data1.length());
                out.write(data2.c_str(), data2.length());
                return TRUE;
        }
        else
        {
                return FALSE;
        }


}




void main()
{
        FLOG flog;
        while (1)
        {
                flog.write("123", "\n");               
                Sleep(1000);   //在VS2013平台下面选择使用静态MFC编译 发现LOG文件不会有任何写入,空白一片,
                                        //把Sleep(1000) 这个注释掉 LOG文件写入正常。
                                        //把静态MFC编译选项改成使用标准WINDOWS库的情次下。LOG文件写入正常
        }                                //实在是想不出来是为什么 只能来论坛找大神求解!!!
}



void main()
{
        FLOG flog;
        while (1)
        {
                flog.write("123", "\n");               
                Sleep(1000);   //在VS2013平台下面选择使用静态MFC编译 发现LOG文件不会有任何写入,空白一片,
                                        //把Sleep(1000) 这个注释掉 LOG文件写入正常。
                                        //把静态MFC编译选项改成使用标准WINDOWS库的情次下。LOG文件写入正常
        }                                //实在是想不出来是为什么 只能来论坛找大神求解!!!

jxlpxcj 发表于 2017-9-2 11:37:07

沙发自已顶!!!

jxlpxcj 发表于 2017-9-2 20:54:40

没人?有没有知道的啦,教下我,百度不到。。

邪魔+ 发表于 2018-6-22 10:51:15

新手路过学习

戚晓栖 发表于 2018-6-23 10:34:01

void FLOG::flush()
{
        out.flush();
}

flog.write("123", "\n");
flog.flush();
Sleep(1000);

试了一下;加一个刷新的函数就可以了;每次写入完成之后调用flush即可;应该是缓存的问题,在调用write时不会真正直接写入文件,而是写入了缓存区,当程序结束或者缓存区写满时会向文件写入
页: [1]
查看完整版本: c++一个奇怪的问题