将调试信息同时输出到终端和文件_暨_多参数函数封装
生活随笔
收集整理的這篇文章主要介紹了
将调试信息同时输出到终端和文件_暨_多参数函数封装
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
今天寫了個類,調試的時候可以將調試語句輸出,同時記錄到文件中??梢杂脕碛汱og,也可以防止終端輸出太快來不及看。其中有一個多參數函數(printf和fprintf)的封裝問題的例子。記錄在此:
#ifndef __IEC_LOG__
#define __IEC_LOG__
#include "string.h"
#define LOG_PATH ".//log//iec104.log"
class IecLog
{
private:
??? FILE *fp;
public:
??? void WOpen()
??? {
??? ??? fp = fopen(LOG_PATH, "w");
??? }
??? void PrintLog(const char *format, ...)
??? {
??? ??? va_list ap;
??? ??? va_start(ap, format);
??? ??? vprintf(format,ap);//輸出到終端
??? ??? if(fp) vfprintf(fp,format,ap);//輸出到文件
??? ??? va_end(ap);
??? ??? fflush(fp);
??? }
};
#endif
用起來也很方便:
1.聲明IecLog iecLog;
2.在程序開頭iecLog.WOpen();//路徑在宏中指定
3.在需要輸出的地方iecLog.PrintLog("the output is %d, another output is %d", int1, int2);
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀
#ifndef __IEC_LOG__
#define __IEC_LOG__
#include "string.h"
#define LOG_PATH ".//log//iec104.log"
class IecLog
{
private:
??? FILE *fp;
public:
??? void WOpen()
??? {
??? ??? fp = fopen(LOG_PATH, "w");
??? }
??? void PrintLog(const char *format, ...)
??? {
??? ??? va_list ap;
??? ??? va_start(ap, format);
??? ??? vprintf(format,ap);//輸出到終端
??? ??? if(fp) vfprintf(fp,format,ap);//輸出到文件
??? ??? va_end(ap);
??? ??? fflush(fp);
??? }
};
#endif
用起來也很方便:
1.聲明IecLog iecLog;
2.在程序開頭iecLog.WOpen();//路徑在宏中指定
3.在需要輸出的地方iecLog.PrintLog("the output is %d, another output is %d", int1, int2);
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀
總結
以上是生活随笔為你收集整理的将调试信息同时输出到终端和文件_暨_多参数函数封装的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 利率基点是什么意思 带你进行详细的了解
- 下一篇: 系统时间大全,待整理