我是靠谱客的博主 开心丝袜,最近开发中收集的这篇文章主要介绍(C++)定制一个可输出更多信息的assert,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

    我们经常用assert来除错,它能告诉我们断言失败的代码行和表达式。但是,有时我们希望能在assert失败时得到更多信息,例如:当GetLastError()  != ERROR_SUCCESS时,还希望将这个ErrorCode到底是多少也显示在assert弹出的对话框中。

    废话就不多说了,直接上代码:

#pragma once

///
// XASSERT:  assert with user-define message, use wide char
///

#include <string>
#include <crtdbg.h>

#ifndef _DEBUG
#define XASSERT(exp_, msgw_) ((void)0)
#else
#define XASSERT(exp_, msgw_) _ASSERT_EXPR((exp_), (std::wstring(L#exp_)+L"rnMessage: "+(msgw_)).c_str())
#endif

    这里大家可以根据需要自行扩展。


    下面是一个调用的例子:

	::OpenProcess(0,0,0);
	XASSERT(GetLastError() == ERROR_SUCCESS, GetErrorString(GetLastError()));



    其中GetErrorString是提取ErrorCode对应的描述信息的函数,定义如下:

std::wstring GetErrorString(DWORD dwErrCode)   
{   
	DWORD dwRet = 0;   
	LPWSTR szResult = NULL;
	std::wstring s;

	dwRet = FormatMessageW(
		FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, 
		NULL,
		dwErrCode,   
		MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_US), 
		(LPWSTR)&szResult,   
		0,   
		NULL);   
	if (dwRet == 0)
	{   
		szResult = NULL;
		return s;
	}   
	s = szResult;
	LocalFree(szResult);
	return s;   
}


最后

以上就是开心丝袜为你收集整理的(C++)定制一个可输出更多信息的assert的全部内容,希望文章能够帮你解决(C++)定制一个可输出更多信息的assert所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部