glog使用: 07-错误信号处理(Failure Signal Handler)

提供了一个方便的信号处理程序,当程序在某些信号(如SIGSEGV)上崩溃时,它将转储有用的信息。

信号处理程序可以通过 google::InstallFailureSignalHandler() 安装。以下是信号处理程序输出的示例:

cpp 复制代码
#include <iostream>

#include <glog/logging.h>

int main(int argc, char* argv[])
{
    (void)argc;//avoid unused warning
    google::InitGoogleLogging(argv[0]);

    // install failure signal handler
    google::InstallFailureSignalHandler();

    //模拟触发段错误
    *(int*)0 = 0;

    //后续不会执行,因为段错误导致程序崩溃
    LOG(FATAL) << "FATAL log message";

    return 0;
}

输出:

shell 复制代码
# ./demo
*** Aborted at 1758626944 (unix time) try "date -d @1758626944" if you are using GNU date ***
PC: @                0x0 (unknown)
*** SIGSEGV (@0x0) received by PID 57 (TID 0x743bde537e40) from PID 0; stack trace: ***
    @     0x743bdd036400 (unknown)
    @           0x400a8e main
    @     0x743bdd022555 __libc_start_main
    @           0x400999 (unknown)
    @                0x0 (unknown)
Segmentation fault (core dumped)

默认情况下,信号处理程序将故障转储写入标准错误。你可以通过 InstallFailureWriter() 自定义目标。

添加相关逻辑,有点怪,原来打印的SIGSEGV错误字样,哪里都找不见了,这不是画蛇添足么...

貌似这个还得建议搭配libunwind使用,等待后续有需要再探索吧。

cpp 复制代码
#include <iostream>
#include <string>

#include <glog/logging.h>

void FailureWriter(const char* data, size_t size)
{
    LOG(FATAL) << std::string(data,size);
}

int main(int argc, char* argv[])
{
    (void)argc;//avoid unused warning
    google::InitGoogleLogging(argv[0]);

    // install failure signal handler
    google::InstallFailureSignalHandler();

    //默认输出到标准错误,可以自定义一个函数来将错误输出到其他地方
    google::InstallFailureWriter(&FailureWriter);

    //模拟触发段错误
    *(int*)0 = 0;

    //后续不会执行,因为段错误导致程序崩溃
    LOG(FATAL) << "FATAL log message";

    return 0;
}

错误输出:

shell 复制代码
# ./demo
F20250923 19:39:11.574347    86 07.cpp:8] *** Aborted at 1758627551 (unix time) try "date -d @1758627551" if you are using GNU date ***
*** Check failure stack trace: ***
    @     0x7af9321d816a  google::LogMessage::Fail()
    @     0x7af9321d80ca  google::LogMessage::SendToLog()
    @     0x7af9321d7917  google::LogMessage::Flush()
    @     0x7af9321db104  google::LogMessageFatal::~LogMessageFatal()
    @           0x400e50  FailureWriter()
    @     0x7af9321e4575  google::(anonymous namespace)::DumpTimeInfo()
    @     0x7af9321e4a26  google::(anonymous namespace)::FailureSignalHandler()
    @     0x7af931236400  (unknown)
    @           0x400ebc  main
    @     0x7af931222555  __libc_start_main
    @           0x400cf9  (unknown)
    @              (nil)  (unknown)
Aborted (core dumped)

日志文件:

shell 复制代码
Log file created at: 2025/09/23 19:39:11
Running on machine: DESKTOP-RR46KEP
Running duration (h:mm:ss): 0:00:00
Log line format: [IWEF]yyyymmdd hh:mm:ss.uuuuuu threadid file:line] msg
F20250923 19:39:11.574347    86 07.cpp:8] *** Aborted at 1758627551 (unix time) try "date -d @1758627551" if you are using GNU date ***
相关推荐
肆忆_9 小时前
# 用 5 个问题学懂 C++ 虚函数(入门级)
c++
chlk12311 小时前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑12 小时前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件12 小时前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
不想写代码的星星12 小时前
虚函数表:C++ 多态背后的那个男人
c++
深紫色的三北六号1 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash1 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI1 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行2 天前
Linux和window共享文件夹
linux
端平入洛2 天前
delete又未完全delete
c++