解决 C 程序内存访问出错办法

重所周知,C编写的程序运行效率高,但是 C 最大的好处和坏处是它允许直接操作内存,如果使用不小心,这就会导致程序的非法推出
而且当程序过大时,此类错误非常难查,下面介绍一种方法,从错误的内存地址反向查找出问题的程序

linux 平台:
1. 在程序信号处理部分, 加入代码捕捉引起错误点的地址,方法参考文章
http://www-128.ibm.com/developerworks/cn/linux/l-sigdebug.html
   简单来说,方法就是在注册自己的信号处理函数,在这个函数中加入获取内存错误地址的代码,并把结果写到一个日志文件中。
2. 编译 DEBUG 版本 程序 (compile 时用 -g , 生成可执行文件后不用 strip 去掉symbol 信息)
3. 在程序出问题时, 查看日志记录, 得到错误点的地址.
4. 用objdump -S  导出Debug 版本的汇编代码, 查找错误地址, 则得出那条语句出错.


windows 下c 语言调试
1. release 版编译/连接选项, 把"generate debug info" 打钩选择
2.dumpbin /DISASM /OUT:dump.out.txt.1 prep.exe 可反编译exe文件
3.得到程序非法地址(可从管理工具-》事件查看器里得到),与汇编比较 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值