VC6的一个bug???

   前几天测试程序的时候发现程序莫名奇妙的死掉,仔细一看原来是指针越界导致的内存访问错误,但是从程序来看并没有越界。

      程序代码类似下面的代码:

int i=0;

for (i=0; i<len; ++i)

{

//访问Array[i]

}

//注释

for (i=0; i<len; ++i)

{

//访问Array[i]

}

 

于是F5调试模式下运行,发现原来是第一个循环结束后,没有设置i0,直接去执行第二个循环体中的代码。

开始怀疑是编译环境的问题,重新设置了环境,清空了所有的东西,重新编译然后执行,结果程序还是死掉。反汇编以后看到第二个循环执行前确实没有设置i0,进而怀疑是VC的问题。用Beyond Compare比较当前文件和以前的版本,提示转换字符失败,马上用UE打开文件查看,结果发现第二个循环与它前一行的注释显示在一行了。

//注释 for (i=0; i<len; ++i)

注释的最后的一个字符显示为?而不是中文字符。肯定是这里出问题了!使用二进制模式查看,最后一个中文字符被删掉了半个,于是编辑器把半个字符和紧接着的0x0D当作了一个中文字符,于是for (i=0; i<len; ++i)也成了注释。但是在VC的编辑器中确实是显示做两行的,没有当作一行,看来VC的编辑器和VC的编译器cl.exe的解析方法不一致,导致二者的行为不一致。

在VC9下使用类似的程序测试,提示warning C4819,编译的结果是正确的。

你可能感兴趣的:(c,汇编,测试,编译器)