C语言strcpy函数所引发的问题

来源:互联网 发布:跳跃网络签到不能用 编辑:程序博客网 时间:2024/06/07 18:14

如下的C语言代码:

[cpp] view plain copy
 print?在CODE上查看代码片派生到我的代码片
  1. #include <stdio.h>   
  2. #include <stdlib.h>   
  3. #include <string.h>   
  4.   
  5. int main()  
  6. {  
  7.   char *a, *b;   
  8.   int i;   
  9.   
  10.   a = (char*) calloc(20, sizeof(char));   
  11.   b = (char*) calloc(20, sizeof(char));   
  12.   
  13.   strcpy(a, "Graduate School of Information Science and Technology");   
  14.   
  15.   for(i = 0; i < 20; i++)   
  16.      printf("b[%d] = %c\n", i, b[i]);   
  17.   return 0;   
  18. }  

已知:

b[11] = T

那么,b[12]、b[13]的值是多少?


在linux上创建一个文件t.c,输入代码,然后编译、运行:

[plain] view plain copy
 print?在CODE上查看代码片派生到我的代码片
  1. [ggg@localhost ~]$ cd Desktop  
  2. [ggg@localhost Desktop]$ ls  
  3. gnome-terminal.desktop  t.c  t.c~  
  4. [ggg@localhost Desktop]$ gcc -o t t.c  
  5. [ggg@localhost Desktop]$ ./t  
  6. b[0] = c  
  7. b[1] = i  
  8. b[2] = e  
  9. b[3] = n  
  10. b[4] = c  
  11. b[5] = e  
  12. b[6] =    
  13. b[7] = a  
  14. b[8] = n  
  15. b[9] = d  
  16. b[10] =    
  17. b[11] = T  
  18. b[12] = e  
  19. b[13] = c  
  20. b[14] = h  
  21. b[15] = n  
  22. b[16] = o  
  23. b[17] = l  
  24. b[18] = o  
  25. b[19] = g  
  26. [ggg@localhost Desktop]$   


论坛会员qldsrx的解释是:
其实是和内存分配是否连续有关,如果两次申请的内存是连续内存空间,那么20字节再加上后面申请内存的头部字节(预估是12字节),这样下面一个申请的20字节正好偏移了32字节



这个时候如果在return之前添加 free(b); 立刻程序崩溃,
因为b这个对象释放时要查找b申请的大小,信息记录在其内存的前面(预估是12个字节),但被改写了。

另外,用visual c++ 6.0尝试了一下,发现数组b中没有任何值,这说明在内存分配上确实和linux平台下的C编译器有很大的差别。

0 0
原创粉丝点击