`
king_tt
  • 浏览: 2084570 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

关于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。这样就不会出现错误了

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics