作者ForWin (For Windows)
看板C_and_CPP
标题[问题] char str[]的用法求解
时间Wed Nov 9 14:03:27 2016
开发平台(Platform): (Ex: Win10, Linux, ...)
Win7
编译器(Ex: GCC, clang, VC++...)+目标环境(跟开发平台不同的话需列出)
TDM-GCC 4.9.2 64-bit Release
问题(Question):
code1:
int main(){
char a[]="Hello ";
char b[]="World!";
strcat(a,b);
printf("%s",a);
printf("%d",strlen(a));
}
code2:
int main(){
char a[6]="Hello ";
char b[6]="World!";
strcat(a,b);
printf("%s",a);
printf("%d",strlen(a));
}
预期的正确结果(Expected Output):
error,因为试图取得没有分配的记忆体
实际结果(Wrong Output):
code1: Hello World!12
code2: Hello World!12
我原本以为
不管是code1或code2,在宣告完後都应该取得阵列大小为7的空间(包含\0)
我去看strcat的source code,也并没有增加a的空间
但两段code都可以印出Hello World!,而且a的长度也都增加了
请问我的观念是否有地方出错了呢?
谢谢指点
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 59.127.185.220
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/C_and_CPP/M.1478671409.A.012.html
1F:推 jerryh001: 你家盖到隔壁去了 邻居不在意的话当然没差 11/09 14:21
2F:推 steve1012: undefined behavior 只是刚好没爆炸而已 11/09 14:22
3F:→ steve1012: 你要知道C/C++是很危险的 存取过界不一定会爆炸 11/09 14:22
4F:→ steve1012: 所以可以的话会多用container.. 比较安全一点 11/09 14:22
谢谢楼上二位,跟我想的差不多
但是连a的长度都增加有点无法理解
因为这样看起来似乎a会自动放大?
尽管我可以占用邻居家,但是我a的大小为什麽会增加@@"
可以讨论看看吗?谢谢
※ 编辑: ForWin (59.127.185.220), 11/09/2016 14:28:53
5F:推 soheadsome: 不是因为a变大 而是他要读\0 11/09 14:37
6F:→ soheadsome: 只能跑到b的位置才看得到 11/09 14:37
7F:→ soheadsome: print strlen看字串结尾都是判断\0 11/09 14:38
8F:推 stupid0319: 这是程式溢位的高级技巧,破解还是骇客都用的到 11/09 14:50
谢谢楼上二位
是我没把strlen搞清楚!!
刚刚试着用sizeof(a)/sizeof(a[0])
发现大小还是一样是7
这样没有问题了!!
谢谢各位!!
※ 编辑: ForWin (223.139.36.33), 11/09/2016 15:04:53
9F:→ pttworld: 这种行为你的问题在不同编译器不保证相同处置。 11/09 15:06