C++ 程序 Crash 的分析

1) 是否容易重现

如果容易,它的复现步骤是什么
如果不容易,它在什么条件下的出现机率比较大,有没有可能缩小排查的范围

2) 是否最近才引入的,发现的时机和频率如何

找出 crash 出现的时间范围,时机,和频率
根据 backgrace 和 git log, 回顾 crash 相关代码的修改记录

3) 灵活运用演绎法,归纳法和二分法

  • 演绎法: 从一般到特殊,从常见的 crash 问题和解决方案推断
  • 归纳法: 从特殊到一般,从最近频发的 crash 问题找出共性特征
  • 二分法: 用二分法合理划分问题域,不断缩小范围
  • 4) 大胆假设,小心求证

    假设条件,测试,排除,不断重复,缩小范围
    有必要时画一张思维导图,记下每条排查路径

    5) 君子性非异也,善假于物也

    查询 google, stackflow, 听取同事的意见

    6) 学学侦破和推理

    最后一条,看看破案和推理小说及剧情,学学侦破技术

  • 如何找线索,
  • 如何勘查现场,
  • 如何排查嫌疑
  • 如何查询积案,进行并案
  • 有一些惯犯和惯用作案手段值得研究

  • 多线程处理不当
    多个线程操作一块内存区域,没有安全地加锁和串行化
    合局和单例对象是重点排查对象

  • 内存处理不当
    内存管理不当,用到的内存却给别人破坏了,例如

  • 试图释放已经释放了的内存
  • 试图释放并未分配的内存
  • 试图读写已经释放了的内存
  • 试图读写并未分配的内存
  • 内存分配错误, 没有正确初始化
  • 读写越界,例如动态分配的数组,列表及类