鱼C论坛

 找回密码
 立即注册
查看: 2798|回复: 4

c++一个奇怪的问题

[复制链接]
发表于 2017-9-2 11:21:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
最近看小甲鱼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[sizeof(char)* 200];
        buff = new char[sizeof(char)* 200];
        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文件写入正常
        }                                //实在是想不出来是为什么 只能来论坛找大神求解!!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2017-9-2 11:37:07 | 显示全部楼层
沙发自已顶!!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-9-2 20:54:40 | 显示全部楼层
没人?有没有知道的啦,教下我,百度不到。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-6-22 10:51:15 | 显示全部楼层
新手路过学习
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-6-23 10:34:01 | 显示全部楼层
void FLOG::flush()
{
        out.flush();
}

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

试了一下;加一个刷新的函数就可以了;每次写入完成之后调用flush即可;应该是缓存的问题,在调用write时不会真正直接写入文件,而是写入了缓存区,当程序结束或者缓存区写满时会向文件写入
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-30 00:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表