这是代码
smem_dmp(char *name, char content[])
{
int i;
int len = strlen(content);
printf("%s\n\n", name);
for(i = 0; i < len; i++)
{
printf("%c\t%p\n", content[i], &content[i] );
}
printf("Done\n\n");
}
print_bar()
{
printf("********************************************************************\n");
}
int main(int argc, char *argv[])
{
char a[16];
char b[16];
strcpy(a, "abcdefghijklmnop");
printf("a = %s\nb = %s\n\n",a,b);
smem_dmp("A", a);
smem_dmp("B", b);
print_bar();
strcpy(b, "ABCDEFGHILKLMNOP");
printf("a = %s\nb = %s\n\n",a,b);
smem_dmp("A", a);
smem_dmp("B", b);
system("PAUSE");
return 0;
}
通过查看 a 和 b 在内存中的位置,我已经弄清楚发生了什么。复制到 b 的字符串不是以空值结尾的。这导致 a 的内容被删除,因为 b 在内存 (0028FF30) 中位于 (0028FF20) 之前。
怎么了?strcpy(b,"string") 在遍历堆栈帧变量上的所有内存之前是否不会停止?抱歉,如果我没有使用正确的术语。:)