【求助】一个奇怪的问题 ———— 直接 Run 和 Debug 结果不一样是怎么回事?

时间:2023-02-09 23:05:14
一个程序,如果直接Run(Ctrl + F5),内存出错;
如果不设断点,Debug Go(F5),不出错。
这两种运行方式应该是一样的,但是运行结果不一样,我知道有人也碰见过同样的问题,但是也不知道原因。
知不知道是怎么回事?

13 个解决方案

#1


Ctrl+F5相当于直接双击exe文件运行
F5是通过VC调试器来跑的,如果有TRACE就看的出来

出错原因我也不知道,换一台机器试一下,可能是VC除问题了

#2


你在出问题的地方前面加上Sleep或AfxMessage看看

#3


有可能vc的问题!

#4


gz

#5


出错的时候应该可以断下来的, 看看是什么地方的问题

#6


是可以找到出错的地方,我就是纳闷,如果我的程序真是有问题,VC调试器会把问题屏蔽掉?
为什么调试的时候有可能就没问题了呢?

#7


绝对是你程序的问题!

类似问题我碰到过,是某处内存使用/访问不当造成的。
直接 Run 和 Debug 的时候,可能程序初始化时的内存构造有些不一样,所以导致不同的行为。
特别要注意变量的初始化问题,尽可能做到所有类的成员变量以及临时变量的值都要赋初值!

#8


某个栈变量没有做合适的初始化。

#9


我认为应该你的程序的问题,虽然说VC也有好多Bug,有可能是你碰到了VC的Bug,这就看你怎么想办法辟开VC的Bug,或者是你的访问内存不当造成了,仔细看看!

#10


编译器没问题,是你的程序有问题!
我遇到过类似问题,一般说来是由于 内存非法操作 引起的。
我告诉你产生此类错误的一个例子,先看下面函数的原形:
strcpy(char *strDestination,const char *strSource);
参数  strDestination 目的字符串
strSource   以空格结尾的源字符串
说明
strcpy函数把strSource包括结尾的空格字符拷贝到strDestination所指的位置。在字符串被拷贝或添加时不执行上溢出检测。如果源和目的字符串重迭,strcpy的行为是不确定的。
-------------------------------------------------
这里要注意的是:在调用strcpy函数之前,strSource的末尾必须为结束符号\0,
否则的话就会出现类似错误,debug时没问题,运行出错。
象下面这样使用就不会出错:
char* tempFile=new char[ftell(m_pFile)+1];//分配内存+1
Read(tempFile,ftell(m_pFile));//Read为使用指定的文件句柄m_pFile,读取指定数量字符的自定义函数
tempFile[ftell(m_pFile)]='\0';//加结束标志,防止潜在错误的发生
strcpy(temp, tempFIle);
SAFE_DELETE(tempFile);

#11


debug环境和程序单独运行时的环境可能会不一样。

#12


程序问题跟vc无关.
你有没有用到多线程呀,我用多线程曾出过这样的问题

#13


同意 ahzhuo(阿卓 
DEBUG时内存会初始化,但运行时不会

#1


Ctrl+F5相当于直接双击exe文件运行
F5是通过VC调试器来跑的,如果有TRACE就看的出来

出错原因我也不知道,换一台机器试一下,可能是VC除问题了

#2


你在出问题的地方前面加上Sleep或AfxMessage看看

#3


有可能vc的问题!

#4


gz

#5


出错的时候应该可以断下来的, 看看是什么地方的问题

#6


是可以找到出错的地方,我就是纳闷,如果我的程序真是有问题,VC调试器会把问题屏蔽掉?
为什么调试的时候有可能就没问题了呢?

#7


绝对是你程序的问题!

类似问题我碰到过,是某处内存使用/访问不当造成的。
直接 Run 和 Debug 的时候,可能程序初始化时的内存构造有些不一样,所以导致不同的行为。
特别要注意变量的初始化问题,尽可能做到所有类的成员变量以及临时变量的值都要赋初值!

#8


某个栈变量没有做合适的初始化。

#9


我认为应该你的程序的问题,虽然说VC也有好多Bug,有可能是你碰到了VC的Bug,这就看你怎么想办法辟开VC的Bug,或者是你的访问内存不当造成了,仔细看看!

#10


编译器没问题,是你的程序有问题!
我遇到过类似问题,一般说来是由于 内存非法操作 引起的。
我告诉你产生此类错误的一个例子,先看下面函数的原形:
strcpy(char *strDestination,const char *strSource);
参数  strDestination 目的字符串
strSource   以空格结尾的源字符串
说明
strcpy函数把strSource包括结尾的空格字符拷贝到strDestination所指的位置。在字符串被拷贝或添加时不执行上溢出检测。如果源和目的字符串重迭,strcpy的行为是不确定的。
-------------------------------------------------
这里要注意的是:在调用strcpy函数之前,strSource的末尾必须为结束符号\0,
否则的话就会出现类似错误,debug时没问题,运行出错。
象下面这样使用就不会出错:
char* tempFile=new char[ftell(m_pFile)+1];//分配内存+1
Read(tempFile,ftell(m_pFile));//Read为使用指定的文件句柄m_pFile,读取指定数量字符的自定义函数
tempFile[ftell(m_pFile)]='\0';//加结束标志,防止潜在错误的发生
strcpy(temp, tempFIle);
SAFE_DELETE(tempFile);

#11


debug环境和程序单独运行时的环境可能会不一样。

#12


程序问题跟vc无关.
你有没有用到多线程呀,我用多线程曾出过这样的问题

#13


同意 ahzhuo(阿卓 
DEBUG时内存会初始化,但运行时不会