【栈越界】栈被破坏导致的死机

linux问题排查实战专栏,分享了作为公司专家,在解决内存、性能、各类死机等疑难问题的排查经验,认真学习可以让你在日后工作中大放光彩。 

       在众多的coredump中,有一类crash调试起来是最麻烦的,那就是“栈被破坏”导致的函数调用回溯结构破坏引发的coredump。本文,主要讲讲这一类crash的成因、原理以及调试方法、如何还原堆栈并定位该问题

(gdb) bt

#0 0x0000000f0000000e in ?? ()

#1 0x0000001100000010 in ?? ()

#2 0x0000001300000012 in ?? ()

#3 0x0000000100000000 in ?? ()

        这种问题在实际开发中其实挺常见的,打印出的堆栈都是问号,可能是栈越界或者库之间头文件不配套导致的栈返回地址被踩,函数执行完之后无法进行栈回溯。无论是哪种原因导致的,其实排查该问题的方法和原理都是一样的。

        如果你对栈有一定的了解,可结合

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值