时间:2016-01-28 16:22:52 作者:zhijie 来源:系统之家 1. 扫描二维码随时看资讯 2. 请使用手机浏览器访问: https://m.xitongzhijia.net/xtjc/20160128/66482.html 手机查看 评论 反馈
有些开发者在Linux下进程编程,使用GDB调试时发现了一个Segmentation fault错误。这个错误主要是访问了错误的内存段引起的,可能是没有权限或者是内存段不存在,这个问题如何处理呢?
方法如下:
这个错误是怎么导致的呢?原来是在定义一个char类型的指针,然后就直接对这个指针进行字符串的相关操作。例如:
char *c1;
for(i=0; i《n;i++)
{
*c1 = getchar();
c1++;
}
代码意思大概是这样,这是很多开发者会犯的问题。这个指针危险啊,要谨慎对待,就拿这里来说,这样给指针赋值,我们并不知道这指针指向的是哪里呢,如果写的数据覆盖了关键区域数据那可能会有灾难性的后果,这就是访问了不该访问的地方。解决的办法是什么呢,告诉这个指针到该到的地方,我用malloc为该指针将要指向的字符串申请一段空间,这样就会指明系统分配一段安全的空间,不会在把内存关键区域分给你了。这样你就可以安全操作了。
这个例子告诉我们指针是不能乱用的,如果指针指向错误的内存,导致编程时出现Segmentation fault错误,还可以用上面的办法处理,如果指向其他区域,还会导致更严重的后果。
发表评论
共0条
评论就这些咯,让大家也知道你的独特见解
立即评论以上留言仅代表用户个人观点,不代表系统之家立场