调试MapWinGIS.OCX,发现断点根本不进入。无论是从MapWinGIS的工程启动,选择MapWindow.exe做为启用程序,还是直接从MapWindow工程启动,调用MapWinGIS.OCX,都不行。
自己写了个测试程序,主窗体用VB,控件用VC。完全仿照MapWindow和MapWinGIS的方式。在控件里下断点,调试。直接进控件的断点了。再把MapWinGIS.OCX加进来,再试,MapWinGIS.OCX的断点没进。比较两个工程文件的差别,没有发现本质上的区别。
写了个VC的主程序,调用MapWinGIS.OCX,断点进入。
VC和VB的调用有什么差别?
后来终于查找原因,MapWinGIS.OCX使用了ATL(在工程设置里写着Not Using ATL,而初始化时干的第一件事情就是ATL的初始化)。VB的主程序是托管的,调用本机的ATL代码,需要把Debugger Type设置为Mixed不能为Auto。(这个的原因还不清楚)。
哪位大大能解释一下ATL,托管,本机代码 的原理。为什么这几个纠结在一起的时候导致断点无法进入,而用VC编写的测试控件能进入断点,照理说,C++写的不也是本机代码吗?
参考:
http://yongliu39.spaces.live.com/Blog/cns!C25D62469C0DC7C8!151.entry
http://msdn.microsoft.com/zh-cn/library/kbaht4dh.aspx