我们知道, 程序segment fault后, 不一定会产生core文件, 如果有core文件, 那还好, 如果没有core或者是坏core, 那该怎么办呢?

       之前我们说过用add2line的方法来定位, 当时用了addr2line和dmesg命令, 今天我们来介绍类似的方法, 以方便在不同场景下多一个思路, 说不定能救命。

       看程序:

#include <iostream>
using namespace std;

int main() 
{
	int *p = NULL;
	*p = 0;

	return 0;
}
      用g++ -g test.cpp来编译, 然后运行./a.out

      我们照样可以用之前的addr2line和dmesg来定位, 试了一下, 可以定位出原因。 下面我们来介绍利用系统log文件和addr2line来定位, 如下:

xxxxxx# ./a.out 
Segmentation fault   (注意: 如果我机器上的core开关打开了, 就会提示Segmentation fault(core dumped), 类似提示大家应该见过, 比如Aborted(core dumped))
xxxxxx# cat /var/log/messages | grep -i seg
Apr  2 15:13:19 yyyyyy kernel: a.out[24764]: segfault at 0 ip 000000000804854f sp 00000000ffc9e7d4 error 6 in a.out[8048000+1000]
xxxxxx# addr2line -e a.out 000000000804854f
/data/home/zzzzzz/test.cpp:7
xxxxxx# 
      done, 问题查出来了。


      以后, 在没有core时, 可以优先看:

      1. /var/log/messages

      2. dmesg

      3. /var/log/dmsg




本文转载:CSDN博客