一个很奇怪的VC++编译问题

类别:编程语言 点击:0 评论:0 推荐:

前几天数据结构上机,帮同学调试程序的时候发现了一个很怪的问题,问题演示如下:

#include "iostream.h"

int main(int argc, char* argv[])
{
        char a[50];
        char b[50];

        cout << "Input a Infix Expresstion : " << endl;
        cin.getline(a,50);

        cout << "a: " << a << endl;
        cout << "b: " << b << endl;

        cin.get();
        cin.get();

        return 0;
}

运算结果:

Input a Infix Expresstion :
2 + 3 * ( 1 + 3 ) + 1 =
a: 2 + 3 * ( 1 + 3 ) + 1 =
b: 烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫烫2 + 3 * ( 1 + 3 ) + 1 =

本来在定义数组的时候,数组A和数组B应该使用是不同的内存空间的,但为什么我用cin.getline()得到的字符串也存到了数组B里去了?

但是如果我把数组B声明时,把它都赋初值为零。改的源程序如下:

#include "iostream.h"

int main(int argc, char* argv[])
{
        char a[50];
        char b[50] = {0}                                                               //赋初值为0;

        cout << "Input a Infix Expresstion : " << endl;
        cin.getline(a,50);

        cout << "a: " << a << endl;
        cout << "b: " << b << endl;

        cin.get();
        cin.get();

        return 0;
}

此时输入结果为:

Input a Infix Expresstion :
2 + 3 * ( 1 + 3 ) + 1 =
a: 2 + 3 * ( 1 + 3 ) + 1 =
b:

用Debug查看数据变化

数组B的数据全部都是0。数据没有发生变化

===================================

问题得到解决了,在这谢谢COMMUNITY.CSDN.NET里的whyglinux 、 whiteseal 、 xzgyb

数组A的内存紧接着数组B的内存后

数组A的 0012FF4C:
0012FF4C  61 73 64 66 00 CC CC  asdf.烫
...

数组B 0012FF18
0012FF18  CC CC CC CC CC CC CC  烫烫烫.
...
0012FF49  CC CC CC 61 73 64 66  烫蘟sdf
0012FF50  00 ...
vc在debug状态下数组内容全初始化为0xCC,所以当读数组B时
一直读到0012FF50处
如果在release,不一定读到哪去

所以显示b的时候找结束符'\0',实际上“2 + 3 * ( 1 + 3 ) + 1 =”是a的内容,显示到这里才找到结束符,典型的越界问题!

定义时a在b的前面的,但为什么在内存中a的空间是0012FF4C>0012FF18
因为a, b作为局部变量,被放在堆栈中。堆栈一般是自底向上增长,所在a > b

本文地址:http://com.8s8s.com/it/it22158.htm