vs2005下部分断点无效的问题

这两天在vs2005下的一个project中进行debug,但是出现了一个比较奇怪的现象,绝大多数文件都可


以设置断点并且可以跟进去,唯独有一个修改量比较大的.cpp文件,前几次还可以设置断点并且跟进


去,后来在那个设置的任何断点都无缘无故失效了。


      把整个project重新build了好几次,包括需要调用的一些第三方的.dll文件都重新生成重新


link,都无法解决问题。就算强行进入这个文件,都会显示该文件与源文件不同,问是否继续。简直


郁闷坏了。


      后来上网查了一些解决方法,其中有一个方法有效的解决了困扰我的问题。该方法说,有可能


是因为在相应的.cpp文件中有中文编码或者其他非ASCII编码,导致文件要更改为unicode格式的形式


才能把信息完全保存下来。同时还提到了一个warning C4819: 该文件包含不能在当前代码页(936)中


表示的字符。请将该文件保存为 Unicode 格式以防止数据丢失


      然后我想起了在rebuild那个project的时候,明明见过这个warning,当时还很奇怪这个


warning是干什么用的。然后想起在那个.cpp文件中有大量的中文注释,会不会是我在注释之外的地方


在中文输入法的情况下输入了譬如回车换行的内容。如果有的话,那应该是紧挨着我写的注释才对。


   于是我把相应的.cpp文件中的注释给删除了。然后重新编译,结果,妥了!哈哈~真是太激动了!


      下面附上网上找到的方法的内容:


最近一工程中,在调试的时候,有些cpp文件都可以设置断点并且跟进去,但是有一个cpp文件总是不


能设置断点,提示“当前不会命中断点。源代码与原始版本不同。” 重新更换过n次文件都不起作用


,然后在goole搜索此类类似问题,找到下篇文章,然后我把那个cpp文件用记事本打开,另存为


unicode格式,再重新编译,最后问题解决!也可以更改vs2005的设置,选项->常规,将要求源文件与


原始版本完全匹配的勾取消就可以了!
清理整个解决方案,重新编译,无效。删除整个目录,从SubVersion服务器上Down下来重新来过,一


样无效。上网搜索,未果。郁闷地放手了。


修一个Bug,提交,然后更新了一下,编译,运行,发现我也染上这个症状了——只有那个文件无法插


入断点。倒有些安心了,看来不是VC的Bug,而是源代码的问题。把这个文件回滚到更新前的版本,果


然就没问题了。更新到下一个版本,问题就出来了。查看改动,没瞧出来什么。忽然发现有一个不常


见的警告:“warning C4819: 该文件包含不能在当前代码页(936)中表示的字符。请将该文件保存为 


Unicode 格式以防止数据丢失”。呵呵,应该就是它了。


警告有两个,一个是文件的,不带行号,另一个带行号。那一行是一个case语句,最后加了一句中文


注释。把注释删掉,问题解决。把代码拷贝到UltraEdit中看十六进制代码,逐个字节滤过去,没发现


什么奇怪的。然后开始逐步逼近问题,把注释前后汉字逐个拿掉,直到问题消失,最后剩下来的核心


词是“即时消息”,搜索这个词,果然在整个项目里只有一个。在这个词前面增、删一个空格,问题


就消失。郁闷的是把同一行代码拷贝到其他文件、位置都不会有这个问题。


恢复所有改动,更新到最新版本,问题又变了:警告只剩下一个,没了行号!用插入空格的方法定位


问题,发现错误向前移动了几行。而且这次就算把警告消掉,还是无法添加断点。尝试了好一会儿没


有效果,干脆用VC直接把整个文件格式化了一次,断点又可以用了。而且,这次再怎么插入空格都不


会有C4819了。对比了一下修改前后的文件,依然没有什么发现。


搜索了一下,其他人也遇到过C4819,有的是因为Unix换行格式,甚至boost库中一个非ASCII作者名都


会引发这个错误,但是这里应该是中文双字节字符错位的问题吧。因为警告等级开到了4,所以各种警


告有些泛滥,他们又没有及时处理,这个警告就被淹没在警告堆里了……


 
PS:个人再加一句,修改vs2005的设置,选项->常规,将要求源文件与原始版本完全匹配的勾取消就


可以了! 这一项网友反映最好不要更改。否则可能引起其他问题,毕竟vs2005默认的就是打勾的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值