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

解决方案 »

  1.   

    Ctrl+F5相当于直接双击exe文件运行
    F5是通过VC调试器来跑的,如果有TRACE就看的出来出错原因我也不知道,换一台机器试一下,可能是VC除问题了
      

  2.   

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

  3.   

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

  4.   

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

  5.   

    编译器没问题,是你的程序有问题!
    我遇到过类似问题,一般说来是由于 内存非法操作 引起的。
    我告诉你产生此类错误的一个例子,先看下面函数的原形:
    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);
      

  6.   

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

  7.   

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