下面的代码,DEBUG版本运行时,结果正确。
可是RELEASE版本运行时,结果错误:
==========================================
out frame: 0
inner framer: 0
out frame: 1
inner framer: 3 <== 结果应该是1,不是3!
out frame: 2
inner framer: 2
out frame: 3
inner framer: 3
==========================================
关键在于inner的framer参数是short型;
Testing中定义的变量iFramer 是int型。如果定义为short iFramer,则RELEASE版本也正常。
另外,用gcc (GCC) 3.4.5 20051201 (Red Hat 3.4.5-2)测试,程序执行结果正确(需要去掉前面两行#include)。
本想跟踪RELEASE的汇编代码,但本人汇编水平太差,只能凑合看看DEBUG版本的汇编。这个问题折磨了我一个整整下午的时间,实在不能解释,只好算作VC6的bug了。
以后写代码,实在不敢顺手写出short, int, long了,一定要看清楚需要什么类型就定义什么类型,否则又说不定撞上什么bug!
#include "stdafx.h"
#include
#include
#include
void inner(short framer)
{
printf("ttinner framer: %dn", framer);
}
void Testing()
{
int trunk = 0;
//short iFramer = 0;
int iFramer = 0;
for (trunk = 0; trunk < 2; trunk++)
{
if (trunk < 100)
{
//Sleep(3000);
iFramer = trunk * 2;
printf("out frame: %dn", iFramer);
inner(iFramer);
iFramer++;
printf("out frame: %dn", iFramer);
inner(iFramer);
}
else
{
iFramer = trunk;
printf("out frame: %dn", iFramer);
inner(iFramer);
}
}
}
int main()
{
Testing();
return 0;
}
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9844649/viewspace-580138/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/9844649/viewspace-580138/