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

以下的C语言代码:linux

 

[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. }  


已知:c++

 

b[11] = T
数组

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


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

 

[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个字节),但被改写了。
.net

 

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

相关文章
相关标签/搜索