C++ 程序 Crash 的分析

1) 是否容易重现

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

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

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

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

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

4) 大胆假设,小心求证

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

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

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

6) 学学侦破和推理

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

  • 如何找线索,
  • 如何勘查现场,
  • 如何排查嫌疑
  • 如何查询积案,进行并案

有一些惯犯和惯用作案手段值得研究

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

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

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

Reference

  • https://blog.csdn.net/fanyamin/article/details/526958?spm=1001.2014.3001.5502
  • https://blog.csdn.net/fanyamin/article/details/1758981?spm=1001.2014.3001.5502
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值