
#include <stdio.h>#include <string.h> int main(){ char name[12] = "Roman Mirov"; printf("My name is %s\n",name); name[8] = 'k'; printf("My name is %s\n",name); char greeting[] = "hello"; printf("%s %s\n",greeting,name); strcpy(greeting,"greetings,"); printf("%s%s\n",name); return 0;} 它输出这个:
My name is Roman MirovMy name is Roman Mikovhello Roman MikovAbort trap: 6
我的问题确切地说,为什么它产生错误而不是显示最后一行作为输出“问候,罗马Mikov”?
解决方法 在这种情况下,目标问候语没有足够的空间来包含源的全部内容,因此它是一个调用 undefined behavior的越界访问.详细说明,数组问候语的大小由提供的初始化程序的大小决定,
char greeting[] = "hello";
在这种情况下,“hello”使大小为6,包括null终止符.
现在,稍后您尝试将更大的字符串放入内存中,
strcpy(greeting,");
其中,源的大小为12字节,而目标只包含6.这会导致边界溢出,结果为UB.崩溃(或中止)是UB可能产生的副作用之一.
@H_502_2@ 总结以上是内存溢出为你收集整理的C中的“中止陷阱:6”错误?全部内容,希望文章能够帮你解决C中的“中止陷阱:6”错误?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)