附錄D 以MFC 重建DBWIN 
我的使用經驗 
現在讓我來談點我使用 Tracewin 的經驗。 
我早就需要在 Visual C++ 使用 DBWIN 了,也早就看到了 Paul DiLascia 的兩篇文 
章,但是真正研讀它並使用其成果,是在我撰寫 /OLE/ActiveX 書(我最新的 
本書,還在孵化之)的時候。也許當你讀到該書,會感嘆侯俊傑怎麼能夠對OLE container 
和 server 之間的交叉動作瞭若指掌。洠в惺颤N,我只是在 container 和 server 之的每 
個我感興趣的函式的開始處,利用 TRACE 輸出些訊息,這樣我就可以從容從 
Tracewin 視窗觀察那些函式的被呼喚時機了。 
所以我在 OLE container 這麼做: 
#include 〃tracewin。h〃 
 。。。 
 BOOL CContainerApp::InitInstance() 
 { 
 。。。 
 pMainFrame…》ShowWindow(m_nCmdShow); 
 pMainFrame…》UpdateWindow(); 
CMfxTrace::Init(); // add by J。J。Hou 
 return TRUE; 
 } 
也在 OLE server 這麼做: 
#include 〃tracewin。h〃 
 。。。 
 BOOL CScribbleApp::InitInstance() 
 { 
 。。。 
 pMainFrame…》ShowWindow(m_nCmdShow); 
 pMainFrame…》UpdateWindow(); 
CMfxTrace::Init(); 
 return TRUE; 
 } 
然後我就可以使用 TRACE 巨集並搭配 Tracewin 看個過癮了。 
933 
…………………………………………………………Page 996……………………………………………………………
 第五篇 附錄 
很好,當這兩個程式獨立執行的時候,切盡如意!但是當我在 container 即編輯 
Scribble item Scribble TRACE Tracewin 
 ,我發現洠в腥魏巍 ∽执伙@示在 視窗。這麼 
來我就觀察不到 Scribble 的交叉作用了呀!於是我想,莫不是兩個程式爭用 afxDump ? 
或是因為兩個 Win32 行程使用不同的位址空間?或是因為。。。 
胡說!洠У览硌健H绻医徊媸褂酶髯元毩⒌摹 ontainer 和 Scribble(不牽扯即編輯), 
它們的 TRACE 結果會交叉出現在 Tracewin 視窗,這就推翻了述的胡思亂想。 
然後我想,會不會是即編輯時根本洠в羞M入 server 的 InitInstance ?如果 
CMfxTrace Init TRACE 
 :: 洠в邢葓绦羞^, 當然就不會輸出到 Tracewin 視窗囉。於是我把 
CMfxTrace Init 
 :: 。。。 。。。 server server 
 改設在 唔 什麼方才是即編輯時 的第個必經之? 
item 是也。於是我這麼做: 
CScribbleItem::CScribbleItem(CScribbleDoc* pContainerDoc) 
 : COleServerItem(pContainerDoc; TRUE) 
 { 
 CMfxTrace::Init(); 
// TODO: add one…time construction code here 
 // (eg; adding additional clipboard formats 
 // to the item"s data source) 
 } 
圖八 Tracewin 
 賓果!我看到了預期的枺鳌! 【褪恰 ∫暣爱嬅妗_@些輸出結果幫助我分析出 
OLE container 和 server 的舉動。 
934 
…………………………………………………………Page 997……………………………………………………………
 附錄D 以MFC 重建DBWIN 
圖八 Tracewin 視窗畫面 
新的視野 
好的除錯工具,不應該要求應用程式碼本身做任何配合性的動作。Paul DiLascia 的 
Tracewin 小工具是個權宜之計。使用稱不太方便(你得含入個 tracewin。h ), 
而且你得有某種程度的技術背景才能把它用得好。不過,說真的,我還是很感謝 Paul 
DiLascia 的創意,讓我們的視野有了新的角度。 
我想你也是。 
935 
…………………………………………………………Page 998……………………………………………………………
 第五篇 附錄 
重建 DBWIN 之 Debug Event 篇 
DBWIN DBWIN 
 自從我開始注意到 之後,我就更加注意期刊有關於 技巧的文章。這 
才發現,好像大家滿喜歡在這個睿空宫F自己傲的功力。像 Paul Dilascia 這樣,以 
MFC DBWIN … MFC programming 
 高階的 來寫 ,當然也就不可能太過「威力」 雖然從 
Paul 。h 
 的技巧來看,我們是學了不少。你知道, 的方法要求你改變你的原始碼,含入個 
檔,並在你的 。cpp 檔加兩行。這在使用的方便性不怎麼高明。 
要高明點,不落痕跡抓到 TRACE 輸出,就必須懂得 Windows 作業系統內部,以 
Windows system programming Matt Pietrek 
 及 。是的,這方面的大師 也寫了個 
DBWIN debug event 
 ,不必影響你的原始碼。不過,他用到 ,以及許多系統知識,不應該 
是本 MFC 書籍適合涵蓋的主睿K裕抑荒茉谶@裡告訴你,可以到 Microsoft 
Systems Journal 1995。07 的 Windows Q/A 專欄學習。程式名稱為 LODPRF32 。此程 
式的主要功能其實是讓你觀察目前所有映射到記憶體的 DLLs 。你可以從知道你的 
EXE DLLs implicitly loading EXE 
 直接或間接使用的所有 。它還會記錄「最後次 
小说推荐
- Java编程思想第4版[中文版](PDF格式)
 - -Page 1-Page 2《Thinking In Java》中文版作者:Bruce Eckel主页:http/BruceEckel.编译:Trans Bot主页:http/memberease~transbot致谢-献给那些直到现在仍在孜孜不倦创造下一代计算机语言的人们!指导您利用万维网的语言进
 - 最新章:第295章
 
- VB2008从入门到精通(PDF格式英文版)
 - -Page 1(R)The eXperT’s Voice inBeginningVB 2008From Novice to ProfessionalChristian Gross-Page 2-Page 3-Beginning VB 2008From Novice to Professional■C
 - 最新章:第214章
 
- oracle从入门到精通(PDF格式)
 - -Page 1-Oracle 从入门到精通-Page 2-资源来自网络,仅供学习 Oracle 从入门到精通一、SQL 8
 - 最新章:第37章
 
- C语言游戏编程从入门到精通(PDF格式)
 - -Page 1-Page 2-Page 3-Page 4-Page 5-Page 6-Page 7-Page 8-Page 9-Page 10-Page 11-Page 12-Page 13-Page 14
 - 最新章:第4章
 
- 深入浅出
 - 《深入浅出》作者:白小骨晋江VIP20140610完结+1番外非V章节总点击数:67370 总书评数:209 当前被收藏数:764 文章积分:11,386,657文案:每个前男友都是女人掉过的坑,从何典阳这个坑里往外爬的梁温暖一脸血表示,何典阳他这个深坑实在太坑爹。何典阳:我是坑?梁温暖…别看我,我
 - 最新章:第74章
 
- 深入浅出[娱乐圈]
 - 文案【忠犬影帝攻X傲娇明星受,1V1轻松甜文,前期互相试探,38章在一起后甜甜甜,两人都有细微的变化和成长~这也是我用心构思攻受感情发展的文,但数据有点太惨了,没入V可以全文免费看,还是想求点收藏呀,数据好看点吧,让我开心一下(笑哭.jpg)流量偶像白漾和影帝顾瑜祁关系很僵,传言两人出道时不合而互相
 - 最新章:第59章
 
- JMS简明教程(PDF格式)
 - -Page 1-JMS1.1规范中文版卫建军2007‐11‐22-Page 2
 - 最新章:第28章
 
- SQL语言艺术(PDF格式)
 - -Page 1-SQLSSQQLL语言艺术内容介绍本书分为12章,每一章包含许多原则或准则,并通过举例的方式对原则进行解释说明。这些例子大多来自于实际案例,对九种SQL经典查询场景以及其性能影响讨论,非常便于实践,为你数据库应用维护人员阅读。资深 SQL 专家 Stéphane Faroult倾力打
 - 最新章:第27章
 
- C语言实例教程(PDF格式)
 - -Page 1-前 言Visual C+是开发运行于Windows 95和Windows NT环境下的Win32应用程序的可视化编程工具中最重要的成员之一,它为软件开发人员提供了完整的编辑、编译和调试工具和建立于Win32 API(ApplicationProgramming Interface)基
 - 最新章:第143章