当前位置: 技术问答>linux和unix
最近频频发生 段错误,gdb最后显示Previous frame inner to this frame (corrupt stack?)的问题.
来源: 互联网 发布时间:2016-03-17
本文导语: gdb -c core.xxx文件查看 有如下显示: #49 0x00000000 in ?? () #50 0x00001000 in ?? () #51 0x00000000 in ?? () #52 0x00001000 in ?? () #53 0x00000008 in ?? () #54 0x00000000 in ?? () #55 0x480381f0 in ?? () #56 0x00000000 in ?? () #57 0x480381...
gdb -c core.xxx文件查看 有如下显示:
#49 0x00000000 in ?? ()
#50 0x00001000 in ?? ()
#51 0x00000000 in ?? ()
#52 0x00001000 in ?? ()
#53 0x00000008 in ?? ()
#54 0x00000000 in ?? ()
#55 0x480381f0 in ?? ()
#56 0x00000000 in ?? ()
#57 0x480381f1 in ?? ()
#58 0x00000000 in ?? ()
#59 0x480381f1 in ?? ()
#60 0x00000000 in ?? ()
#61 0x00083be1 in ?? ()
#62 0x00000000 in ?? ()
#63 0x00737e98 in ?? ()
#64 0xbfffb384 in ?? ()
#65 0x00000001 in ?? ()
#66 0xbfffb258 in ?? ()
#67 0x0804cf21 in file2str (file=0x738780 "01") at utils.c:129
Previous frame inner to this frame (corrupt stack?)
file2str这个函数用来将文件的内容返回为一个字符串:
char*
file2str(const char* file)
{
int fd;
int fsize; /*file size*/
struct stat sb;
char* str = NULL;
fd = open (file, O_RDONLY);
if(-1 == fd)
{
perror (""); //108行
return NULL;
}
fstat (fd, &sb);
fsize = sb.st_size;
/*获得文件大小*/
str = xnew_array (char, fsize + 1);
/*为str分配空间*/
if (!str)
{
close (fd);
return NULL;
}
if (fsize != read (fd, str, fsize))
{
xfree (str);
close (fd);
return NULL;
}
str[fsize] = ''; //129行
close(fd);
return str;
}
除了在129行发生段错误外,有时还会在108行perror出现问题.
#49 0x00000000 in ?? ()
#50 0x00001000 in ?? ()
#51 0x00000000 in ?? ()
#52 0x00001000 in ?? ()
#53 0x00000008 in ?? ()
#54 0x00000000 in ?? ()
#55 0x480381f0 in ?? ()
#56 0x00000000 in ?? ()
#57 0x480381f1 in ?? ()
#58 0x00000000 in ?? ()
#59 0x480381f1 in ?? ()
#60 0x00000000 in ?? ()
#61 0x00083be1 in ?? ()
#62 0x00000000 in ?? ()
#63 0x00737e98 in ?? ()
#64 0xbfffb384 in ?? ()
#65 0x00000001 in ?? ()
#66 0xbfffb258 in ?? ()
#67 0x0804cf21 in file2str (file=0x738780 "01") at utils.c:129
Previous frame inner to this frame (corrupt stack?)
file2str这个函数用来将文件的内容返回为一个字符串:
char*
file2str(const char* file)
{
int fd;
int fsize; /*file size*/
struct stat sb;
char* str = NULL;
fd = open (file, O_RDONLY);
if(-1 == fd)
{
perror (""); //108行
return NULL;
}
fstat (fd, &sb);
fsize = sb.st_size;
/*获得文件大小*/
str = xnew_array (char, fsize + 1);
/*为str分配空间*/
if (!str)
{
close (fd);
return NULL;
}
if (fsize != read (fd, str, fsize))
{
xfree (str);
close (fd);
return NULL;
}
str[fsize] = ''; //129行
close(fd);
return str;
}
除了在129行发生段错误外,有时还会在108行perror出现问题.
|
虽然在这两个地方报错,但是不一定错误就在这两个地方。
有可能在调用这个函数前,就有溢出或越界的情况。
因为perror就把不应该会出错。
有可能在调用这个函数前,就有溢出或越界的情况。
因为perror就把不应该会出错。
您可能感兴趣的文章:
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。