- 作者:佚名
- 时间:2016-10-09
对于开发者来说,如果在Linux下进行编程,那么在使用GDB调试时,会发现了一个Segmentation fault错误。对于这样的错误主要是访问了错误的内存段引起,这样的问题,可能是没有权限或者是内存段不存在,关于这样的问题我们应该怎样进行解决呢?
方法如下:
这个错误是怎么导致的呢?原来是在定义一个char类型的指针,然后就直接对这个指针进行字符串的相关操作。例如:
char *c1;
for(i=0; i《n;i++)
{
*c1 = getchar();
c1++;
}
代码意思大概是这样,这是很多开发者会犯的问题。这个指针危险啊,要谨慎对待,就拿这里来说,这样给指针赋值,我们并不知道这指针指向的是哪里呢,如果写的数据覆盖了关键区域数据那可能会有灾难性的后果,这就是访问了不该访问的地方。解决的办法是什么呢,告诉这个指针到该到的地方,我用malloc为该指针将要指向的字符串申请一段空间,这样就会指明系统分配一段安全的空间,不会在把内存关键区域分给你了。这样你就可以安全操作了。
以上的例子告诉我们指针是不能乱用的,如果指针指向错误的内存,导致编程时出现Segmentation fault错误,还可以用上面的办法处理,如果指向其他区域,还会导致更严重的后果。
可以到老毛桃U盘启动制作工具www.laomaotao.cn.com。更多精彩内容继续关注