linux中,怎样定位段错误在哪一行??
发布网友
发布时间:2022-04-21 19:18
我来回答
共1个回答
热心网友
时间:2023-12-12 11:12
1. 段错误是什么
一句话来说,段错误是指访问的内存超出了系统给这个程序所设定的内存空间,例如访问了不存在的内存地址、访问了系统保护的内存地址、访问了只读的内存地址等等情况。这里贴一个对于“段错误”的准确定义(参考Answers.com):
A segmentation fault (often shortened to segfault) is a particular error condition that can occur ring the operation of computer software. In short, a segmentation fault occurs when a program attempts to access a memory location that it is not allowed to access, or attempts to access a memory location in a way that is not allowed (e.g., attempts to write to a read-only location, or to overwrite part of the operating system). Systems based on processors like the Motorola 68000 tend to refer to these events as Address or Bus errors.
Segmentation is one approach to memory management and protection in the operating system. It has been superseded by paging for most purposes, but much of the terminology of segmentation is still used, "segmentation fault" being an example. Some operating systems still have segmentation at some logical level although paging is used as the main memory management policy.
On Unix-like operating systems, a process that accesses invalid memory receives the SIGSEGV signal. On Microsoft Windows, a process that accesses invalid memory receives the STATUS_ACCESS_VIOLATION exception.
2. 段错误产生的原因
2.1 访问不存在的内存地址
#include<stdio.h>
#include<stdlib.h>
void main()
{
int *ptr = NULL;
*ptr = 0;
}
2.2 访问系统保护的内存地址
#include<stdio.h>
#include<stdlib.h>
void main()
{
int *ptr = (int *)0;
*ptr = 100;
}
2.3 访问只读的内存地址
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void main()
{
char *ptr = "test";
strcpy(ptr, "TEST");
}
2.4 栈溢出
#include<stdio.h>
#include<stdlib.h>
void main()
{
main();
}
等等其他原因。
3. 段错误信息的获取
程序发生段错误时,提示信息很少,下面有几种查看段错误的发生信息的途径。
3.1 dmesg
dmesg可以在应用程序crash掉时,显示内核中保存的相关信息。如下所示,通过dmesg命令可以查看发生段错误的程序名称、引起段错误发生的内存地址、指令指针地址、堆栈指针地址、错误代码、错误原因等。以程序2.3为例:
panfeng@ubuntu:~/segfault$ dmesg
[ 2329.479037] segfault3[2700]: segfault at 80484e0 ip 00d2906a sp bfbbec3c error 7 in libc-2.10.1.so[cb4000+13e000]
3.2 -g
使用gcc编译程序的源码时,加上-g参数,这样可以使得生成的二进制文件中加入可以用于gdb调试的有用信息。以程序2.3为例:
panfeng@ubuntu:~/segfault$ gcc -g -o segfault3 segfault3.c
3.3 nm
使用nm命令列出二进制文件中的符号表,包括符号地址、符号类型、符号名等,这样可以帮助定位在哪里发生了段错误。以程序2.3为例:
panfeng@ubuntu:~/segfault$ nm segfault3
08049f20 d _DYNAMIC
08049ff4 d _GLOBAL_OFFSET_TABLE_
080484dc R _IO_stdin_used
w _Jv_RegisterClasses
08049f10 d __CTOR_END__
08049f0c d __CTOR_LIST__
08049f18 D __DTOR_END__
08049f14 d __DTOR_LIST__
080484ec r __FRAME_END__
08049f1c d __JCR_END__
08049f1c d __JCR_LIST__
0804a014 A __bss_start
0804a00c D __data_start
08048490 t __do_global_ctors_aux
08048360 t __do_global_dtors_aux
0804a010 D __dso_handle
w __gmon_start__
0804848a T __i686.get_pc_thunk.bx
08049f0c d __init_array_end
08049f0c d __init_array_start
08048420 T __libc_csu_fini
08048430 T __libc_csu_init
U __libc_start_main@@GLIBC_2.0
0804a014 A _edata
0804a01c A _end
080484bc T _fini
080484d8 R _fp_hw
080482bc T _init
08048330 T _start
0804a014 b completed.6990
0804a00c W data_start
0804a018 b dtor_idx.6992
080483c0 t frame_mmy
080483e4 T main
U memcpy@@GLIBC_2.0
3.4 ldd
使用ldd命令查看二进制程序的共享链接库依赖,包括库的名称、起始地址,这样可以确定段错误到底是发生在了自己的程序中还是依赖的共享库中。以程序2.3为例:
panfeng@ubuntu:~/segfault$ ldd ./segfault3
linux-gate.so.1 => (0x00e08000)
libc.so.6 => /lib/tls/i686/cmov/libc.so.6 (0x00675000)
/lib/ld-linux.so.2 (0x00482000)
罪魁查找Linux下段错误的罪魁linux定位段错误的是
首先,Linux系统出错时会产生日志文件,如/var/log/messages等,这是我们第一步要查看的。通常情况下,系统会在其中添加一些跟踪消息,可以用来分析哪里有错误。其次,Unix和Linux系统都提供了task manager来监控系统资源。系统中存在无效的进程或消耗系统资源过多的进程,都可能导致程序出现错误。再次,我们...
linux c 段错误如何定位
程序发生段错误时,提示信息很少,下面有几种查看段错误的发生信息的途径。3.1 dmesg dmesg可以在应用程序crash掉时,显示内核中保存的相关信息。如下所示,通过dmesg命令可以查看发生段错误的程序名称、引起段错误发生的内存地址、指令指针地址、堆栈指针地址、错误代码、错误原因等。以程序2.3为例:panfeng@...
段错误(core dumped)”只知道跟数据库 有关,但不知道如何解决,请高人帮 ...
Linux 程序在遇到段错误(常见的是由非法访问内存引起)的时候会产生 core 文件,如果这个程序包含调试信息(编译的时候加 -g 选项),那么使用 gdb 读取这个 core 文件可以快速定位出错的源代码。原来在某软件公司实习的时候(用 RedHat Enterprise Linux)觉得这样非常方便查错,但我自己用的 Debian GNU/...
linux段错误
首先 要明白一点,任何的段错误,都是内存分配有错误,在编译的时候 把 -g 加上,然后用gdb调试,看错误出现的位置,再分析……gdb显示第26行有错误
执行linux定时脚本是报错 Segmentation fault,求高手指正!在线等。_百 ...
这一行是你执行的程序把 ?请你查看一下你的程序,是否出现了空指针未指向内存就引用或者数组越界。你说你正常执行时候没有问题,很有可能你在正常执行你的程序的时候传递的没有导致程序出现错误,可以打印出发生段错误的时候的脚本中传递给程序的参数值,然后另开终端以此参数值调用下程序看下。段错误,...
Linux编程时段错误会是什么情况系引起的,不要ctrl+c,ctrl+V,最讨厌那种...
gdb调试你的程序,运行到出错的地方它会停下来,这个时候你用bt命令看一下调用堆栈,就知道是代码里什么地方的问题了。
LINUX下汇编出现 段错误(核心已转储)
回答:你先调下吧 gdb ./hello core 看看那里错了
linux下gcc 编程 段错误(核心已转储) 大神救我,折磨我一天了..._百度...
在的所在.c文件的目录中 在终端里面敲 1. ulimit -c unlimited 2. 在用gcc编译时,在最后加上-g 3. 运行一次错误代码,出现段错误后, 目录中有一个core文件 4. 运行:gdb ./a.out core 会自动帮你找出可能出错的代码,出现段错误一般都是越界了 ...
linux c内存溢出的core dump bug怎么跟
浅析Linux下core文件 当我们的程序崩溃时,内核有可能把该程序当前内存映射到core文件里,方便程序员找到程序出现问题的地方。最常出 现的,几乎所有C程序员都出现过的错误就是“段错误”了。也是最难查出问题原因的一个错误。下面我们就针对“段错误”来分析core文件的产生、以及我们 如何利用core文件找到...
段错误的段错误的常见形式
在编程中以下几类做法容易导致段错误,基本上是错误地使用指针引起的。1)访问系统数据区,尤其是往系统保护的内存地址写数据最常见就是给一个指针以0地址。2)内存越界(数组越界,变量类型不一致等): 访问到不属于你的内存区域。解决方法:我们在用C/C++语言写程序的时候,内存管理的绝大部分工作都是...