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