EVC入门之二: 在未被加载的DLL中设置断点 (虽然没有遇到这个问题,不过先摘抄下来)

问题:

这个问题居然也郁闷了我一段时间。 我们假设在EVC里建立了一个project, 里面有SubProject_1(以下简称SB1,嘿嘿), 编译生成一个EXE; SubProject_2(以下简称SB2)编译生成一个DLL;并且已经设置好SB1 "depend on" SB2,  在SB1运行的时候, 使用LoadLibrary函数动态加载SB2.DLL. 那么, 如果我在SB1和SB22里面各加断点若干, 然后按下F5(GO), 就会出现这样的警告框

 



这时候如果程序停在SB1里的断点时,按CTRL+B看一看,就会发现SB1里面的断点仍然存在, 而SB2里面的断点已经被diable掉了, 如图

 



这时候如果你试图去把那些勾勾点上,EVC就跳出来说“No code exists at the line number for breakpoint", 如下图。

 



以前临时的解决方法是在LoadLibrary之后加一个断点,当程序停在那里时,再调出这个Breakpoint List, 对里面被DISABLE掉的断点重新ENABLE。 但这是SB1 LOAD SB2的简单情况,如果还有SB3,SB4,SB5.... 并且会根据运行时的情况在IF语句里加载,那就更麻烦了,每个LoadLibrary后面加断点停下来,然后去手工ENABLE……那就真的SB了。


解决方法:

在EVC里Project -> Settings, 然后切换到SB1这个SubProject, 右边选Debug sheet, 然后在Category里面选”Additional DLLs",  在Modules里面添加需要”预加载“的DLL。对于我现在编译PC本地代码,然后下载到目标板上运行的情况,只要设置Local Name就行了,如下图



这样在GO的时候,首先是DOWNLOADING,然后在Debug Ouput Window会看到这样几行
Loaded symbols for 'D:\SOURCE_CODE\BreakPointSample\SB2\ARMV4IDbg\SB2.dll'
Loaded symbols for 'D:\SOURCE_CODE\BreakPointSample\SB3\ARMV4IDbg\SB3.dll'
SB1.exe

也就是说,在运行SB1之前,已经预加载了SB2和SB3, 这样未在代码中加载的DLL里设置的断点就不会被DISABLE掉了。如果不加入这些Addtional DLLs, 那么在DOWNLOAD结束后, Debug ouput里只显示
SB1.exe
然后马上弹出文中第一个警告框说breakpoints have been disabled.

特别强调一点,修改Additional DLLs后不需要重新编译就能起效果. 预加载DLL和编译代码本身没联系.

本方法适用于EVC和VC, 而VS和PB里面是"you can set a breakpoint on a DLL that is not yet loaded. The Additional DLLs dialog box no longer exists"的, 所以用惯了PB的人换EVC时, 在这个问题上要被卡一下.

参考文章:
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/vsdebug/html/_asug_setting_breakpoints.asp
关键点在最后"Limitations and Changes"这一小段里.

posted @ 2013-07-06 11:34  OleNet  阅读(307)  评论(0编辑  收藏  举报