zoukankan      html  css  js  c++  java
  • 使用CFile生成log文件的方法

    下面实例是在退出程序点击退出按钮时,在主程序的根目录下生成一个Log记录,用来记录程序的退出时间,具体实现代码与调试代码如下:

    void CDebugDlg::OnClose()
    {
     // TODO: 在此添加消息处理程序代码和/或调用默认值
     
     CFile file;
     CTime time=CTime::GetCurrentTime();

     CString str1="记录系统退出时间为:";
     CString str2=time.Format("%y-%m-%d %H:%M:%S");
     CString str3=" ";
     unsigned char pchData[MAX_PATH]={0};

     file.Open("Log.txt",CFile::modeCreate|CFile::modeNoTruncate|CFile::modeReadWrite);
     file.Read(pchData,MAX_PATH);

     if (MessageBox("你是否确定现在退出软件?","系统提示",MB_OKCANCEL|MB_ICONQUESTION)==IDOK)
     {
      
      str1+=str2;
      str1+=str3;
      MessageBox(str1,"提示一");
      file.Write(str1,str1.GetLength());
      MessageBox(str1+(char*)pchData,"提示二");  //打印当前缓冲区文件中的数据

      OnCancel();
     }

    实例二:

    相对实例一中的代码来说,只是在代码一的基础上,在log输出文件中增加了打印当前应用程序标题名,其中标题名由title变量变示,具体修改如下:

    void CDebugDlg::OnClose()
    {
     // TODO: 在此添加消息处理程序代码和/或调用默认值
     
     CFile file;
     CTime time=CTime::GetCurrentTime();

     CString str1="----系统退出时间为:";
     CString str2=time.Format("%y-%m-%d %H:%M:%S");
     CString str3=" ";
     CString title="";
     unsigned char pchData[MAX_PATH]={0};

     GetWindowText(title);  //获取应用程序标题名

     file.Open("Log.txt",CFile::modeCreate|CFile::modeNoTruncate|CFile::modeReadWrite);
     file.Read(pchData,MAX_PATH);

     if (MessageBox("你是否确定现在退出软件?","系统提示",MB_OKCANCEL|MB_ICONQUESTION)==IDOK)
     {
      title+=str1;
      title+=str2;
      title+=str3;
      MessageBox(title,"提示一");

      file.Write(title,title.GetLength());
      MessageBox(title+(char*)pchData,"提示二");  //打印当前缓冲区文件中的数据

      OnCancel();
     }
    }

  • 相关阅读:
    servlet中getWriter和getOutputStream的区别
    一个页面访问错误的问题
    sendRedirect实现原理分析
    servlet开发细节
    tomcat 目录分析
    servlet杂谈
    SQL 查询中的like子句的另一种实现方法,速度比like快
    让复合控件的子控件获得设计时支持
    bug管理工具——Gemini
    HtmlAgilityPack获取#开头节点的XPath
  • 原文地址:https://www.cnblogs.com/jinjiangongzuoshi/p/3294552.html
Copyright © 2011-2022 走看看