鱼C论坛

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

c++一个奇怪的问题

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

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

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

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

  1. #include <iostream>
  2. #include <fstream>
  3. #include <string>
  4. #include <windows.h>
  5. #include <stdio.h>

  6. class FLOG
  7. {
  8. public:
  9.         FLOG();                                    //类的构造函数
  10.         ~FLOG();                                                                        //类的析构函数       
  11.         BOOL write(std::string data);                                //写入函数
  12.         BOOL write(std::string data, std::string data1); //写入函数的重载
  13.         BOOL write(std::string data, std::string data1, std::string data2); //写入函数的重载

  14. private:
  15.         SYSTEMTIME time;
  16.         std::ofstream out;
  17.         char *filename;
  18.         char *buff;
  19.         BOOL rejet;
  20. };

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

  28.         if (out.is_open())   //如果文件打开成功,设置REJET为真,否则为假
  29.         {
  30.                 rejet = TRUE;
  31.         }
  32.         else
  33.         {
  34.                 rejet = FALSE;
  35.         }
  36. }

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

  43. BOOL FLOG::write(std::string data)
  44. {
  45.         if (rejet)      //如果REJET为真 则写入数据到文件
  46.         {
  47.                 int i;
  48.                 GetLocalTime(&time);
  49.                 i = sprintf_s(buff, 200, "%d-%d-%d %d:%d:%d\t", time.wYear, time.wMonth, time.wDay, time.wHour, time.wMinute, time.wSecond);
  50.                 out.write(buff, i);
  51.                 out.write(data.c_str(), data.length());
  52.                 return TRUE;
  53.         }
  54.         else
  55.         {
  56.                 return FALSE;
  57.         }




  58. }

  59. BOOL FLOG::write(std::string data, std::string data1)
  60. {
  61.         if (rejet)
  62.         {
  63.                 int i;
  64.                 GetLocalTime(&time);
  65.                 i = sprintf_s(buff, 200, "%d-%d-%d %d:%d:%d\t", time.wYear, time.wMonth, time.wDay, time.wHour, time.wMinute, time.wSecond);
  66.                 out.write(buff, i);
  67.                 out.write(data.c_str(), data.length());
  68.                 out.write(data1.c_str(), data1.length());
  69.                 return TRUE;
  70.         }
  71.         else
  72.         {
  73.                 return FALSE;
  74.         }

  75. }

  76. BOOL FLOG::write(std::string data, std::string data1, std::string data2)
  77. {
  78.         if (rejet)
  79.         {
  80.                 int i;
  81.                 GetLocalTime(&time);
  82.                 i = sprintf_s(buff, 200, "%d-%d-%d %d:%d:%d\t", time.wYear, time.wMonth, time.wDay, time.wHour, time.wMinute, time.wSecond);
  83.                 out.write(buff, i);
  84.                 out.write(data.c_str(), data.length());
  85.                 out.write(data1.c_str(), data1.length());
  86.                 out.write(data2.c_str(), data2.length());
  87.                 return TRUE;
  88.         }
  89.         else
  90.         {
  91.                 return FALSE;
  92.         }


  93. }




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



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-3-28 20:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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