问题:
这个问题居然也郁闷了我一段时间。 我们假设在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 co
以前临时的解决方法是在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_CO
Loaded symbols for 'D:\SOURCE_CO
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时, 在这个问题上要被卡一下.