文档章节

使用OutputDebugString替换掉TRACE

seanking
 seanking
发布于 2016/02/16 12:00
字数 304
阅读 769
收藏 0

#程序员薪资揭榜#你做程序员几年了?月薪多少?发量还在么?>>>

使用TRACE调试很方便,但是在Unicode环境下确老是问题多多,经常会出现令人郁闷的识别问题。

_CrtDbgReport: String too long or IO Error

虽然可以通过setlocale函数来设置语言页,但是仅支持一种语言,如果需要同时显示多种语言就很令人无语。,此外TRACE有最大输出长度的限制(1K)

class XCLILocale
{
public:
	XCLILocale(void)
	{	m_strLocale = _tsetlocale(LC_ALL,_T(""));	}

	virtual ~XCLILocale(void)
	{	_tsetlocale(LC_ALL,m_strLocale);	}
public:
	LPCTSTR m_strLocale;
};
void main(void)
{
    XCLILocale locale;
    TRACE(_T("测试Test\n"));
}

Windows提供了一个API函数OutputDebugString用来向output窗口输出信息,该函数有OutputDebugStringW (Unicode) and OutputDebugStringA (ANSI)两个版本。

字符串长度无限制(至少我输出了一个约25K的XML文件就没啥问题,用TRACE最多显示一部分)。

不过使用OutputDebugString函数不支持printf 风格的格式化。需要预先格式化字符串。不过可以用CString类的FormatV函数封装一下,封装代码如下:

void __cdecl XTrace(LPCTSTR strFormat, ...)
	{
		va_list argList;
		va_start(argList, strFormat);

		CString str;
		str.FormatV(strFormat,argList);

		va_end(argList);

		OutputDebugString(str);
	}

至此,使用XTrace函数终于可以替代TRACE宏,在output窗口中自由输出测试信息了


© 著作权归作者所有

seanking
粉丝 3
博文 14
码字总数 5960
作品 0
杭州
高级程序员
私信 提问
VC调试时输出调试信息到Debug窗口

TRACE宏(afx.h, AfxTrace) (TRACE将信息输出到afxDump对象,只在_DEBUG定义时输出,最多输出512个字符,格式化与printf类似) afxDump对象(afx.h, CDumpContext) (afxDump调用OutputDebugString...

simpower
2018/07/18
345
0
TRACE宏的使用方法

TRACE宏对于VC下程序调试来说是很有用的东西,有着类似printf的功能;该宏仅仅在程序的DEBUG版本中出现,当RELEASE的时候该宏就完全消失了,从而帮助你调试也在RELEASE的时候减少代码量。 使...

长平狐
2012/10/08
182
0
liudegui/log4cplus

#log4cplus 基于log4cplus修改 修改内容: 只支持Windows和Linux平台,去掉其他平台的支持(vs2010和gcc4.4测试通过)。 去除unicode的支持 只保留consoleAppender、fileAppender;并添加cus...

liudegui
2014/08/18
0
0
[译]Ocelot - Headers Transformation

原文 Add to Request 为上游请求添加请求头,只需如下一样将下面的配置添加到一个ReRoute里: 上面的例子中添加了一个键为Uncle,值为Bob的请求头。 支持Placeholders。 Add to Response 还可...

osc_715mam6n
2018/09/06
1
0
error C2664: 'OutputDebugStringW' : cannot conv...

错误信息:error C2664: 'OutputDebugStringW' : cannot convert parameter 1 from 'char [100]' to 'LPCWSTR' 1> Types pointed to are unrelated; conversion requires reinterpret_cast, ......

稀饭桶子
2013/03/07
299
0

没有更多内容

加载失败,请刷新页面

加载更多

PHP实战之文件上传与下载

目录 1. 前言 2.代码实战 2.1客户端页面配置说明 2.2 $_FILES预定义变量解析 2.3文件的移动方式 2.3.1第一种移动形式 2.3.2第二种移动形式 2.4文件上传配置及解析 2.5 错误信息说明 3. 文件上...

六道木
17分钟前
16
0
rebar3 的使用

安装 $ git clone https://github.com/erlang/rebar3.git$ cd rebar3$ ./bootstrap $ ./rebar3 local install===> Extracting rebar3 libs to ~/.cache/rebar3/lib...===> Writing r......

SummerGao
19分钟前
20
0
聊聊nifi的AbstractBinlogTableEventWriter

序 本文主要研究一下nifi的AbstractBinlogTableEventWriter AbstractBinlogTableEventWriter nifi-1.11.4/nifi-nar-bundles/nifi-cdc/nifi-cdc-mysql-bundle/nifi-cdc-mysql-processors/src......

go4it
20分钟前
18
0
如何解决Git中的合并冲突 - How to resolve merge conflicts in Git

问题: 如何解决Git中的合并冲突? 解决方案: 参考一: https://stackoom.com/question/g5t/如何解决Git中的合并冲突 参考二: https://oldbug.net/q/g5t/How-to-resolve-merge-conflicts-...

fyin1314
23分钟前
23
0
最常用的linux命令

查看磁盘挂载情况: df -h 查看当前目录下每个文件夹的大小 du -lh --max-depth=1 清空特定文件root >root 查看安装的linux发型版本 cat /proc/version *******lsb_release -a uname --m 查看...

fairy1674
27分钟前
22
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部