青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

大熊的口袋

 

vc下格式化輸出調試診斷信息(TRACE)

最近在將一個dll工程從一個大的項目里抽出來,避免依賴其他的亂七八糟的lib和dll,作為一個獨立的dll工程。將包含工程文所有主要代碼的文件夾拷出來一編譯,問題一大堆,其中最扎眼的要數TRACEA()TRACEW()TRACEW1()TRACEW2()這些未定義的宏了。想把原先的宏定義拉過來,卻總覺得這些TRACE1、2之類的實在是不太雅觀。并且如果依賴原先的實現可能要要再帶一個dll(那我抽出來的目的是什么?),遂自己實現了一個任意個參數的TRACE宏,廢話少說,上代碼:
// --debuginfo.h
#ifndef __DEBUG_INFO_H__
#define __DEBUG_INFO_H__

#ifndef NDEBUG
#define TRACEA ((void)0)
#define TRACEW ((void)0)
#else
VOID _cdecl _traceA(
const char *msgFmt, );
VOID _cdecl _traceW(
const wchar_t *msgFmt, );

#define TRACEA _traceA
#define TRACEW _traceW
#endif

#endif
//--debuginfo.cpp
#include "debuginfo.h"
#include 
<stdlib.h>
#include 
<Windows.h>

#ifndef NDEBUG

__declspec(thread) unsigned retAddrForTraceA 
= 0;
__declspec(thread) 
char tszBuf[512= {0};

__declspec(thread) unsigned retAddrForTraceW 
= 0;
__declspec(thread) wchar_t tswzBuf[
512= {0};


static unsigned *GetAddrOfRetAddrForTraceA()
{
    
return &retAddrForTraceA;
}


static unsigned *GetAddrOfRetAddrForTraceW()
{
    
return &retAddrForTraceW;
}


static char *GetAddrOftszBuf()
{
    
return &tszBuf[0];
}


static wchar_t *GetAddrOftswzBuf()
{
    
return &tswzBuf[0];
}



_declspec(naked) VOID _traceA(
const char *msgFmt, )
{
    __asm 
{
        call GetAddrOfRetAddrForTraceA;
        pop ebx;
        mov [eax], ebx;
        call GetAddrOftszBuf;
        push eax;
        call dword ptr [wsprintfA];
        call dword ptr [OutputDebugStringA];
        call GetAddrOfRetAddrForTraceA;
        push [eax];
        ret;
    }

}


_declspec(naked) VOID _traceW(
const wchar_t *msgFmt, )
{
    __asm 
{
        call GetAddrOfRetAddrForTraceW;
        pop ebx;
        mov [eax], ebx;
        call GetAddrOftswzBuf;
        push eax;
        call dword ptr [wsprintfW];
        call dword ptr [OutputDebugStringW];
        call GetAddrOfRetAddrForTraceW;
        push [eax];
        ret;
    }

}


#endif

這個trace是線程安全的。避免了自己去分析格式字符串。

終于,工程再編譯一次,結果安靜多了...

posted on 2009-11-04 16:35 大熊的口袋 閱讀(3153) 評論(1)  編輯 收藏 引用 所屬分類: cpp

評論

# re: vc下格式化輸出調試診斷信息(TRACE) 2009-11-06 11:22 喜樂遞女性購物

吉薩匯商大廈  回復  更多評論   

導航

統計

公告

常用鏈接

留言簿(2)

隨筆分類

隨筆檔案

win32 & debug

搜索

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久麻豆一区二区| 亚洲国产视频一区二区| 一本一本久久a久久精品综合麻豆| 免费亚洲电影在线| 亚洲毛片av| 日韩视频在线观看免费| 欧美三级日本三级少妇99| 午夜一区不卡| 久久久久国产精品麻豆ai换脸| 亚洲激情校园春色| 日韩一区二区电影网| 国产欧美在线看| 欧美ed2k| 国产精品久久九九| 久久在线免费观看| 欧美在线观看一二区| 欧美国产日韩一区二区| 欧美日韩一卡二卡| 欧美一区二区在线免费观看| 久久人人精品| 亚洲一区在线看| 久久精品国产精品亚洲| 亚洲最新视频在线播放| 久久国产欧美| 中文日韩欧美| 另类图片综合电影| 午夜精品福利视频| 免费一级欧美片在线观看| 亚洲免费在线视频一区 二区| 欧美在线|欧美| 亚洲一级高清| 欧美 日韩 国产 一区| 欧美一区三区三区高中清蜜桃| 免播放器亚洲一区| 欧美一区二区视频在线观看| 欧美精品成人一区二区在线观看| 久久福利影视| 国产精品v一区二区三区| 欧美激情无毛| 在线日韩精品视频| 午夜精品国产更新| 亚洲夜间福利| 欧美日韩国产美女| 亚洲电影第三页| 极品少妇一区二区| 亚洲欧美激情视频在线观看一区二区三区| 亚洲日本免费| 久久综合电影一区| 久久蜜桃香蕉精品一区二区三区| 国产精品久久久久久久久久直播 | 国产精品国码视频| 亚洲人被黑人高潮完整版| 亚洲大胆美女视频| 久久久高清一区二区三区| 欧美专区在线观看| 国产日产欧美精品| 亚洲欧美中日韩| 香蕉精品999视频一区二区| 欧美日韩免费在线| av不卡免费看| 亚洲欧美日韩在线观看a三区 | 久久久人人人| 久久综合狠狠综合久久综青草 | 在线亚洲欧美视频| 欧美日韩亚洲一区二区三区在线观看| 亚洲福利一区| 一区二区三区|亚洲午夜| 欧美不卡一卡二卡免费版| 亚洲高清三级视频| 日韩一级精品视频在线观看| 欧美乱妇高清无乱码| 亚洲精一区二区三区| 亚洲午夜精品网| 国产精品天美传媒入口| 午夜精品视频在线观看| 久久久精品久久久久| 久久不射中文字幕| 亚洲精品乱码久久久久| 免费在线成人av| 亚洲精品一区中文| 午夜国产精品视频| 韩国成人精品a∨在线观看| 久久久久九九九| 亚洲欧洲一区二区天堂久久| 一个人看的www久久| 国产麻豆精品theporn| 久久人人爽国产| 亚洲精品欧美一区二区三区| 亚洲愉拍自拍另类高清精品| 韩国av一区二区三区| 男人插女人欧美| 亚洲视频大全| 欧美好骚综合网| 亚洲免费伊人电影在线观看av| 国产婷婷97碰碰久久人人蜜臀| 蜜桃久久精品一区二区| 亚洲一区黄色| 亚洲第一精品夜夜躁人人躁 | 国产欧美一区二区精品性色| 蜜桃久久精品乱码一区二区| 亚洲视频一区二区| 嫩草国产精品入口| 午夜精品三级视频福利| 1769国产精品| 国产视频一区三区| 欧美日韩国产三级| 久色婷婷小香蕉久久| 亚洲欧美国产精品专区久久| 亚洲国产欧美精品| 久久精品国产99精品国产亚洲性色 | 国产精品女人网站| 免费国产自线拍一欧美视频| 亚洲欧美999| 亚洲人成在线播放| 久久久久久一区二区三区| 亚洲视频一区二区免费在线观看| 狠狠色丁香婷综合久久| 国产精品盗摄一区二区三区| 欧美激情亚洲国产| 久久亚洲高清| 欧美在线影院| 午夜国产一区| 中文欧美字幕免费| 亚洲精品在线视频观看| 亚洲电影成人| 欧美国产综合视频| 麻豆精品视频在线观看| 久久精品成人欧美大片古装| 香蕉成人久久| 先锋资源久久| 欧美一区免费| 欧美一区国产在线| 亚洲欧美一区二区三区在线| 亚洲一二三区精品| 一区二区欧美亚洲| 一本大道久久a久久综合婷婷| 亚洲伦理在线观看| 日韩视频三区| 一区二区三区视频在线播放| 一区二区激情视频| 一本在线高清不卡dvd | 国外成人在线视频| 国产一区二区三区网站| 极品少妇一区二区三区| 国内精品一区二区| 在线日韩欧美| 亚洲美女中文字幕| 久久激情视频免费观看| 久久久九九九九| 久久琪琪电影院| 免费日韩成人| 欧美激情精品久久久久久大尺度| 欧美大片专区| 欧美日韩小视频| 国产伦精品一区二区三区免费迷| 国产小视频国产精品| 在线播放亚洲一区| 亚洲美女视频| 欧美制服丝袜| 欧美成人69av| 在线综合亚洲| 久久er99精品| 欧美精品免费在线| 国产精品―色哟哟| 精品99一区二区| aa亚洲婷婷| 久久精品国产免费观看| 免费h精品视频在线播放| 91久久嫩草影院一区二区| 亚洲视频axxx| 免费一级欧美片在线播放| 国产精品www色诱视频| 狠狠噜噜久久| 亚洲影院免费观看| 久久综合99re88久久爱| 91久久在线| 欧美中文在线观看国产| 欧美激情精品久久久久久免费印度| 国产精品国色综合久久| 亚洲国产激情| 欧美伊人久久大香线蕉综合69| 欧美国产激情| 亚洲欧美日韩国产| 欧美久色视频| 伊人色综合久久天天| 亚洲性线免费观看视频成熟| 免费观看成人网| 亚洲欧美在线另类| 欧美日韩高清在线| 亚洲国产精品成人| 午夜电影亚洲| 亚洲九九九在线观看| 久久一区中文字幕| 国产亚洲激情| 亚洲欧美日韩直播| 日韩网站在线观看| 欧美 日韩 国产 一区| 影视先锋久久| 久久免费午夜影院| 午夜精品福利在线观看|