关于Segmentation fault (core dumped)的错误

牢骚

   话说这个错误很可恶啊,昨天下午一直都有,吃完饭回来又弄,一直弄到最后要回宿舍的时候,寻思着再试一次吧,竟然查到错误了。我的程序是书上的例程,不能全信书啊!先简单记一下。

错误原因

   我是受到网上这段提示“无非就是一些细节的原因,比如:声明了指针但是没有初始化,结果再后来的时候进行间接引用 ”,比如,

char  *p;

char  test[]="Hello" ;

strcpy(p,test);

上一段话出自;http://www.cnblogs.com/gudai/archive/2006/06/27/436601.html

而我的错误是这样的,我在做共享内存的实验时,有这样一段:

char  *buff;

char  *shm_addr;

fgets(buff,2048,stdin);//到这里还没出现错误

strncpy(shm_addr,buff,strlen(buff));   //到这里就出现错误了

我编译没有错误,运行时,当输入 hello时,提示出现Segmentation fault (core dumped),如下图


受到上面的启发,我将 char  *buff;  一句修改成了  char buff[20]; 没错误了,并且程序运行正常了。

今天仔细一分析原因,才明白原来是我定义了指针 buff,但是在第4句中用strlen(buff),来求该指针所指的类型的长度,这家伙长度我也没给它定义,不溢出才怪呢。修改成 char  buff[20]后,buff就是该数组的首地址,长度就为20。这样就不会出现错误了

你可能感兴趣的:(c,fault,segmentation)