一个经典的问题的思考: strcpy覆盖内存

转自:http://m.blog.csdn.net/shanchangyi/article/details/52058501

#include
#include

int main(void) {
    char s[]="123456789";
    char d[]="123";

    strcpy(d,s);

    printf("%s,\n%s",d,s);

    return 0;
}

一个经典的问题的思考: strcpy覆盖内存_第1张图片

查看各个字节的地址 d的四个字节的地址分别为 fee2,fee3,fee4,fee5
s的十个字节的地址分别为 fee6,fee7,fee8,fee9·······feef;
压栈中向下生长,由高地址压入低地址,先压栈s中 ‘/0’ ,然后’9’8 7·············然后压入d的/0 3 2 1;

在strcpy前插入断点,运行前

一个经典的问题的思考: strcpy覆盖内存_第2张图片

运行过以后结果如下图所示:
一个经典的问题的思考: strcpy覆盖内存_第3张图片

可知 d为123456789
s为56789
d和s内存连续 ,复制时将他们的某些值覆盖,才导致了上述问题,那么应该怎样解决呢?

1.

#include
#include

int main()
{
    char s[10]="123456789";
    char d[10]="123";
    strcpy(d,s);
    printf("%s,\n%s",d,s);


    return 0;
}

2.

#include
#include

int main()
{
  char *s=(char*)malloc(10);
  char *d=(char*)malloc(10)
    strcpy(d,"123456789");
    strcpy(s,"123456789"); 
    printf("%s,\n%s",d,s);
    return 0;
}

你可能感兴趣的:(C,总结)