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

穩定盈利的期貨交易方法-量化趨勢交易

alantop -專業量化投資者

愛好:量化投資,逆向工程,滲透
隨筆 - 595, 文章 - 0, 評論 - 921, 引用 - 0
數據加載中……

調試程序的一種方法:

用了一下dbwin很方便。

下載的地方: http://dilascia.com/TraceWin.htm

我用vc6, 所以下載 3.0

用的時候非常方便,在使用的文件前#include "TraceWin.h"

這樣,后afxDump和Trace的字符串,都輸入到TraceWin.exe這個程序中了。

調試ole, c/s的程序非常方便。



后面附上源碼:

////////////////////////////////////////////////////////////////
//?TraceWin?Copyright?1995-1999?Paul?DiLascia
//?If?this?program?works,?it?was?written?by?Paul?DiLascia.
//?If?not,?I?don't?know?who?wrote?it.
//
//?NOTE:?If?you're?using?PixieLib,?you?don't?need?to?include?this?file.
//?It's?already?included?by?the?library.
//
//?***************************************************************************
//?TraceWin?is?a?tool?that?displays?MFC?diagnostic?(afxDump,?TRACE)?output
//?in?the?window?of?the?TraceWin?applet.
//
//?To?use?TraceWin,?you?must?#include?this?file?somewhere?in?your?main?program
//?file?(typically?where?you?implement?your?CWinApp).?Since?this?file?contains
//?code,?you?should?#include?it?in?only?once--i.e.?NOT?in?StdAfx.h--or?you'll
//?get?multiply-defined?symbol?errors?in?the?linker.?This?file?contains?an
//?auto-initializing?static?variable?that?works?in?most?cases;?but?you?may?miss
//?some?TRACE?output?from?constructors?of?static?objects.?If?so,?you?can
//?manually?call?PxlTraceInit?before?your?first?TRACE?call.
//
//?To?see?the?output,?you?also?need?the?TraceWin?applet,?TraceWin.exe,?which
//?you?can?download?http://pobox.com/~dilascia
//
//?***************************************************************************
//
#ifdef?_DEBUG

//?Window?class?name?used?by?the?main?window?of?the?TRACEWIN?applet.
#define?TRACEWND_CLASSNAME?_T("TraceWin?TRACE?Window")
#define?OLDTRACEWND_CLASSNAME?_T("MfxTraceWindow")?//?backwards?compat

//?ID?sent?as?COPYDATASRUCT::dwData?to?identify?the?WM_COPYDATA?message
//?as?coming?from?an?app?using?TraceWin.
#define?ID_COPYDATA_TRACEMSG?MAKELONG(MAKEWORD('t','w'),MAKEWORD('i','n'))

//////////////////
//?CFileTrace?is?a?CFile?that?"writes"?to?the?trace?window
//
class?CFileTrace?:?public?CFile?{
????DECLARE_DYNAMIC(CFileTrace)
????CFileTrace()?
{?m_strFileName?=?_T("Mfx?File?Tracer");?}
????
static?BOOL?autoInit;
????
virtual?void?Write(const?void*?lpBuf,?UINT?nCount);
public:
????
static??BOOL?Init();????
}
;
IMPLEMENT_DYNAMIC(CFileTrace,?CFile)

//////////////////
//?Override?to?write?to?TraceWin?applet?instead?of?file.
//
void?CFileTrace::Write(const?void*?lpBuf,?UINT?nCount)
{
????
if?(!afxTraceEnabled)
????????
return;????//?MFC?tracing?not?enabled

????HWND?hTraceWnd?
=?::FindWindow(TRACEWND_CLASSNAME,?NULL);
????
if?(hTraceWnd==NULL)
????????hTraceWnd?
=?::FindWindow(OLDTRACEWND_CLASSNAME,?NULL);
????
if?(hTraceWnd)?{
????????
//?Found?Trace?window:?send?string?with?WM_COPYDATA
????????
//?Must?copy?to?make?me?the?owner?of?the?string;?otherwise
????????
//?barfs?when?called?from?MFC?with?traceMultiApp?on
????????
//
????????static?char?mybuf[1024];

#ifdef?_UNICODE
????????BOOL?bDefCharUsed;
????????::WideCharToMultiByte(CP_ACP,
0,LPCWSTR(lpBuf),
????????????
-1,?mybuf,?1024,?NULL,?&bDefCharUsed);
#else
????????memcpy(mybuf,?lpBuf,?nCount);
#endif

????????COPYDATASTRUCT?cds;
????????cds.dwData?
=?ID_COPYDATA_TRACEMSG;
????????cds.cbData?
=?nCount;
????????cds.lpData?
=?mybuf;
????????CWinApp
*?pApp?=?AfxGetApp();
????????HWND?hWnd?
=?pApp???pApp->m_pMainWnd->GetSafeHwnd()?:?NULL;
????????::SendMessage(hTraceWnd,?WM_COPYDATA,?(WPARAM)hWnd,?(LPARAM)
&cds);
????}

????
//?Also?do?normal?debug?thing
????::OutputDebugString((LPCTSTR)lpBuf);
}


/////////////////
//?Initialize?tracing.?Replace?global?afxDump.m_pFile?with?CFileTrace?object.
//?In?VC?5.0,?you?shouldn't?need?to?call?this,?since?it's?called?from?an
//?auto-initializing?static?object?autoInit?below.?But?if?you?don't?see
//?any?TRACE?output?in?the?TraceWin?window,?you?should?try?calling
//?PxlTraceInit?any?time?before?your?first?TRACE?message.
//
BOOL?CFileTrace::Init()
{
????
if?(afxDump.m_pFile==NULL)?{
????????
//?Initialize?tracing:?replace?afxDump.m_pFile?w/my?own?CFile?object
????????
//
????????
//?It's?important?to?allocate?with?"new"?here,?not?a?static?object,
????????
//?because?CFileTrace?is?virtual--i.e.,?called?through?a?pointer?in
????????
//?the?object's?vtbl--and?the?compiler?will?zero?out?the?virtual
????????
//?function?table?with?a?NOP?function?when?a?static?object
????????
//?goes?out?of?scope.?But?I?want?my?CFileTrace?to?stay?around?to
????????
//?display?memory?leak?diagnostics?even?after?all?static?objects
????????
//?have?been?destructed.?So?I?allocate?the?object?with?new?and
????????
//?never?delete?it.?I?don't?want?this?allocation?to?itself?generate
????????
//?a?reported?memory?leak,?so?I?turn?off?memory?tracking?before?I
????????
//?allocate,?then?on?again?after.
????????
//
????????BOOL?bEnable?=?AfxEnableMemoryTracking(FALSE);
????????afxDump.m_pFile?
=?new?CFileTrace;
????????AfxEnableMemoryTracking(bEnable);
????????
return?TRUE;
????}

????
return?FALSE;
}


//////////////////
//?This?object?does?nothing?but?call?CFileTrace::Init,?so?all?you?have?to
//?do?is?#include?this?file.?Because?afxDump?is?defined?in?a?module?with
//
//?#pragma?init_seg(lib)
//
//?afxDump?gets?initialized?before?the?"user"?segment?which?is?where?your
//?app?(and?autoInit)?is?by?default.?If?you?need?to?use?init_seg(lib),
//?or?you?have?other?objects?whose?constructors?call?TRACE?that?get
//?initialized?before?CFileTrace::bInitialized,?you?will?have?to?call
//?CFileTrace::Init?yourself,?before?your?first?TRACE?statement.
//
BOOL?CFileTrace::autoInit?=?CFileTrace::Init();

//?This?symbol?defined?so?you?can?call?it?and?have?it
//?compile?to?nothing?in?non-debug?build
#define?PxlTraceInit()?CFileTrace::Init();

#else

#define?PxlTraceInit()

#endif?//?_DEBUG

posted on 2006-05-07 15:57 AlanTop 閱讀(1315) 評論(4)  編輯 收藏 引用 所屬分類: C++

評論

# re: 調試程序的一種方法:  回復  更多評論   

這個還不是最方便的

最簡單的方法是使用DebugView,不用改代碼,就可以直接看到調試輸出了
2006-05-08 09:11 | 小明

# re: 調試程序的一種方法:  回復  更多評論   

小明,說得不錯,我一般還要對OutputDebugString進行一些封裝,并增加一個調試宏,這樣在Release版本中,就沒有任何的輸出了,很方便!
2006-05-08 22:40 | vgoo

# re: 調試程序的一種方法:  回復  更多評論   

方法很多,寫到一個console窗口里面也是可以的。
quake的做法是自己寫了一個os無關的console類,無論在windows上還是linux,mac都可以出trace
2006-05-10 12:38 |

# re: 調試程序的一種方法:  回復  更多評論   

不曉得有不有試過 XTRACE
可以在release 下查看輸出的
2006-05-15 16:06 | 代李
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美专区中文字幕| 欧美一区二区三区视频免费| 欧美1区视频| 亚洲一区国产精品| 久久精品国产久精国产爱| 亚洲韩国精品一区| 亚洲女性喷水在线观看一区| 亚洲大黄网站| 亚洲欧美第一页| 在线亚洲观看| 久久久人成影片一区二区三区观看| 亚洲免费精品| 欧美精品免费视频| 欧美黑人国产人伦爽爽爽| 国产女主播一区二区三区| 亚洲国产婷婷香蕉久久久久久99| 国产精品免费一区二区三区在线观看 | 日韩亚洲一区二区| 亚洲高清毛片| 欧美精品激情blacked18| 亚洲国产成人精品久久| 在线观看久久av| 久久一区二区三区超碰国产精品| 久久国产直播| 在线成人h网| 久久综合九色综合久99| 欧美www视频在线观看| 亚洲人成7777| 欧美人交a欧美精品| 中文精品视频| 久久久九九九九| 亚洲欧洲日韩综合二区| 欧美日韩成人一区| 香港久久久电影| 欧美1区视频| 亚洲一区二区免费看| 欧美午夜精品久久久久久久| 欧美亚洲综合久久| 91久久国产综合久久| 欧美一区二区三区免费看| 亚洲高清激情| 国产精品视频免费在线观看| 久久综合成人精品亚洲另类欧美| 日韩午夜免费| 欧美www视频在线观看| 亚洲专区免费| 99av国产精品欲麻豆| 在线高清一区| 国产日韩视频| 欧美亚洲成人精品| 毛片一区二区| 噜噜噜在线观看免费视频日韩| 99视频有精品| 亚洲夜间福利| 亚洲视频在线观看三级| 99精品福利视频| 亚洲精品一区二区三区99| 久久综合网hezyo| 美女诱惑一区| 你懂的亚洲视频| 欧美激情四色| 国产精品二区在线| 国产精品影片在线观看| 国产精品视频久久一区| 国产欧美日本一区二区三区| 国内视频一区| 亚洲国产日韩一区| 国产精品99久久久久久www| 午夜欧美不卡精品aaaaa| 欧美在线影院| 亚洲国产欧美久久| 亚洲一区二区三区中文字幕| 小辣椒精品导航| 老司机精品久久| 欧美日韩中文字幕在线视频| 国产区亚洲区欧美区| 91久久线看在观草草青青| 日韩午夜免费| 久久亚洲综合色| 亚洲一区二区三区免费观看 | 樱桃成人精品视频在线播放| 亚洲精品免费观看| 久久福利毛片| 国产精品99久久久久久久久| 久久久久久久综合日本| 欧美日本一道本| 亚洲国产日韩一级| 美女视频一区免费观看| 小黄鸭精品密入口导航| 欧美日韩国产成人在线观看| 激情成人av| 久久久www| 亚洲一区二区在线看| 国产精品久久久久久久电影| 亚洲激情av在线| 欧美激情小视频| 蜜臀a∨国产成人精品| 亚洲国产日韩美| 最新日韩精品| 欧美片第一页| 亚洲一区二区三区四区五区黄| 亚洲欧洲综合| 国产精品久久久久免费a∨大胸| 亚洲神马久久| 亚洲一区影音先锋| 国内精品一区二区| 亚洲高清久久| 国产精品日韩欧美| 老色批av在线精品| 欧美精品系列| 在线视频亚洲| 久久精品亚洲精品国产欧美kt∨| 尤妮丝一区二区裸体视频| 免费中文日韩| 国产精品老牛| 欧美二区在线看| 国产精品sm| 最新中文字幕一区二区三区| 国产伦精品一区二区三区高清版| 久久国产欧美日韩精品| 免费日韩一区二区| 欧美在线你懂的| 欧美性大战久久久久久久蜜臀| 久久久久一区| 国产精品久久久99| 91久久精品国产91性色| 国产亚洲第一区| 亚洲欧美日韩视频一区| 99精品视频网| 久久亚洲精品视频| 久久男女视频| 国产自产精品| 欧美一区二区三区视频在线| 亚洲欧美激情诱惑| 欧美视频手机在线| 日韩亚洲在线| 亚洲调教视频在线观看| 欧美日韩免费观看一区=区三区| 亚洲国产欧美一区二区三区同亚洲| 狠狠色丁香久久婷婷综合_中| 亚洲一区欧美激情| 久久久91精品国产| 国语自产在线不卡| 久久久久久久波多野高潮日日| 欧美在线一区二区| 一区免费视频| 欧美精品在线观看一区二区| 日韩视频不卡| 久久久99精品免费观看不卡| 亚洲成色www8888| 欧美福利电影网| 亚洲欧美日韩高清| 欧美国产精品人人做人人爱| 亚洲一级一区| 亚洲国产高潮在线观看| 欧美日韩精品是欧美日韩精品| 一本一本久久a久久精品牛牛影视| 欧美中文在线字幕| 亚洲美女免费精品视频在线观看| 国产精品v欧美精品v日韩精品| 久久精品国产2020观看福利| 99re6热只有精品免费观看| 久久精品视频在线观看| 一个色综合导航| 1769国产精品| 激情久久久久久久| 国产精品系列在线| 欧美日韩精品在线观看| 麻豆成人综合网| 久久久一二三| 久久精品综合网| 久久精品99| 久久久久这里只有精品| 午夜日韩视频| 久久久久久久激情视频| 性久久久久久久久久久久| 亚洲一区二区少妇| 午夜精品久久久久久久99热浪潮 | 国产精品久久久久久久久久久久| 欧美国产精品v| 欧美麻豆久久久久久中文| 欧美极品一区二区三区| 欧美日韩国产三级| 国产精品高潮在线| 亚洲乱码视频| 亚洲承认在线| 国产精品h在线观看| 欧美高清在线一区| 伊人成年综合电影网| 欧美在线视频一区二区三区| 99精品欧美| 欧美无乱码久久久免费午夜一区| 亚洲福利视频免费观看| 久久理论片午夜琪琪电影网| 亚洲区一区二区三区| 久久久久久久久蜜桃| 国产精品日日做人人爱| 亚洲欧洲在线免费| 久久久精品网| 欧美一区二区三区四区视频|