WinCE LOG 输出到文件(串口)控制

原创 2016年08月26日 08:53:38
WinCE7 + Telechips 8935,通过串口输出 LOG 时,可能是由于多个应用同时使用串口输出 LOG,会出现 LOG 混乱的情况。
出现这种情况后,LOG 完全是乱的,根本没有办法看。 修改的方法是:将 LOG 写入 U 盘中,形成一个文件。
写文件的操作很简单,但如何将 RETAILMSG 的格式转成字符串呢?
但由于我负责这个应用是主控,负责各个应用之间的调度,写的过程中增加了很多 RETAILMSG 和 printf 的 LOG 输出以方便分析问题,统计了一下大概有 800 个左右,大多数是 RETAILMSG。
如果需要一个个修改,我只能考虑放弃。考虑到 RETAILMSG 是一个宏定义,能否通过一个自定义的、类似的宏代替它,这样对源代码的修改就可以尽可能的少。

先是实现了一个如下定义的宏:RETMSG,可以完成将 RETAILMSG 后的变参格式转成字符串。简单的测试后,发现可以达到想要的功能。
#ifndef _RET_MSG_H_
#define _RET_MSG_H_
#include "atlstr.h"

#define LOG_FILE_PATH	L"/hard disk"
#define LOG_FILE_NAME	L"/hard disk/logFileName.dat"
#define MAX_UNICODE_LEN	2048

void InitWriteFileCs(void);
void DeleteWriteFileCs(void);
void WriteAnsiDataToFile(const char *pcDataBuf);

#define RETMSG(cond,printf_exp)	\
{ \
	CString csDataBuf; \
	char cTmpBuf[2 * MAX_UNICODE_LEN + 1]; \
	csDataBuf.Format printf_exp; \
	WriteAnsiDataToFile(csDataBuf); \
}

#endif

但是由于我的应用没有使用 MFC,虽然整合编译通过,但是运行时报错了。只要执行这句:csDataBuf.Format printf_exp; 就会有异常的信息输出。
出错的原因,偶只是怀疑与多线程相关(因为在简单的 MFC 对应框中测试是可以正常使用的)。因为偶的应用中有多个线程,每个线程之间异步运行。

不能使用 CString,让我头痛了一段时间。没有关系,关键是我想找一个与 CString.Format 相同参数的格式化字符串的函数。
但是没有! 看来想通过简单的方法是不行了,开始考虑使用 wsprintf/sprintf 函数。
如何将这两个函数 wsprintf/sprintf 的第一个参数代入 wsprintf/sprintf printf_exp 中?
后来实在没有办法,只能将 wsprintf/sprintf 的第一个参数写在 RETMSG 的调用中,如:
RETMSG(1,(gtcRetMsgBuf,L"[MP]show UI,show page id: 0x%x failed!!!\r\n",pageid));
这样就可以得到类似的语句:
wsprintf(gtcRetMsgBuf,L"[MP]show UI,show page id: 0x%x failed!!!\r\n",pageid);
从而完成字符串格式的功能。
同样,完成替代 printf 的宏定义。
#ifndef _RET_MSG_H_
#define _RET_MSG_H_

#define LOG_FILE_PATH	L"/hard disk"
#define LOG_FILE_NAME	L"/hard disk/logFileName.dat"
#define MAX_UNICODE_LEN	(2048 + 1)

void WriteAnsiDataToFile(const char *pcDataBuf);
void WriteUnicodeDataToFile(TCHAR *ptcDataBuf);

extern TCHAR gtcRetMsgBuf[];
extern char gcRetMsgBuf[];

#define RETMSG(cond,printf_exp)	\
{ \
	if(cond) \
	{ \
		ZeroMemory(gtcRetMsgBuf,sizeof(TCHAR) * MAX_UNICODE_LEN); \
		wsprintf printf_exp; \
		WriteUnicodeDataToFile(gtcRetMsgBuf); \
	} \
}

#define RETMSG_printf(printf_exp) \
{ \
	ZeroMemory(gcRetMsgBuf,sizeof(char) * MAX_UNICODE_LEN); \
	sprintf printf_exp; \
	WriteAnsiDataToFile(gcRetMsgBuf); \
} \

#endif

多线程时,引功能需要增加了临界区,否则会出现 LOG 被覆盖的问题。

再考虑到刚启动时 U 盘的识别可能慢,所以后续增加了缓冲的功能......

想要完善一个功能,真是不容易啊!


WinCE系统下应用崩溃原因的分析方法

做为程序员,最怕什么?Bug?大家都清楚,调试期的 Bug 并不可怕,那怕是那些神龙见首不见尾的 INT(随机、没有规律) Bug。 做为嵌入式程序员,也是一样的。一般来说嵌入式系统都提供了异常分析...

wince驱动快速编译的方法

wince驱动快速编译的方法      creator      sz111@126.com      注:不知何种原因,图片显示不了,我做了一个pdf文件,大家可以下载。      这...

WinCE6.0 USB Host驱动加载流程详解(二)

zhuanzi 无语,编辑了好多遍了,还是显示不正常,就这样吧。     今天分析USB HOST Class部分的驱动内容。         CLASS目录实现的是Client层驱动程序,通过调用...
  • joji_h
  • joji_h
  • 2014年12月09日 10:06
  • 929

wince中写中文log文件

项目中用到的,起先log会有一串小方框,后来发现是写入的长度并不是实际转化后的长度,备忘。 自定义函数MyWideCharToMultiByte,功能:将含有中文的宽字符数组转化为多字节字符数组,返...

OK6410 SD卡一键烧写WinCE6.0串口输出消息

Welcome! This tool just for TE/OK6410 +OALArgsInit() SocID:0x36410101                 Arguments a...

wince串口驱动-串口调用流程:先创建注册表,用文件函数打开:

串口调用流程:先创建注册表,用文件函数打开:     // SPL-test-1Dlg.cpp : 实现文件 // #include "stdafx.h" #include "SPL-...

保存log时,根据不同级别采用不同颜色区分,文件保存为Html或者输出到控制台

为了保持可扩展性,将控制台颜色设置和保存文件颜色设置分别用两个头文件。 此外,因为log可能需要在整个工程的不同类中输出信息,因此将文件输出类中设计为静态数据成员,方便调用。 很简单,直接看代码吧。...

log4j多文件输出打印

  • 2011年06月21日 21:07
  • 2KB
  • 下载

LOG4J的配置..实现了输出到控制台、文件、回滚文件、发送日志邮件

Log4J配置文件实现了输出到控制台、文件、回滚文件、发送日志邮件、输出到数据库日志表、自定义标签等全套功能。择其一二使用就够用了, log4j.rootLogger=DEBUG,CONSOLE...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:WinCE LOG 输出到文件(串口)控制
举报原因:
原因补充:

(最多只允许输入30个字)