免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5147 | 回复: 4
打印 上一主题 下一主题

内存写越界——如何实时监控一个地址里的值? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-10-22 23:56 |只看该作者 |倒序浏览
问题大概是这样的:
我把malloc进行了一个封装,就称为wrapper_malloc吧,使得用户申请的空间有一个头部
和一个4字节的尾部,以便于调试和问题定位,用户真正应该使用的是中间那部分,wrapp
er_malloc返回的也是中间部分的首地址。4字节的尾部固定为一个魔鬼数字。
我wrapper_malloc(n)个字节的空间,系统运行一段时间后,我们发现这块空间尾部的那个
魔鬼数字变了,也就是说存在写越界的情况。但由于系统很庞大,所以很难通过静态地看
代码找出是哪个地方写越界了。于是乎,我就想了这样一种方法——在那块空间申请后,
会返回中间部分的首地址,由于能获取用户申请的空间的长度,所以我就可以计算出4字节
尾部的首地址。刚开始这4个字节里存储的肯定是那个魔鬼数字。现在,我就想实时监控这
个尾部的值,只要它的值不是那个魔鬼数字了,我就立马记录下改写这个尾部的代码所在
的文件及行号。

但具体的办法,我琢磨了很久,不知道有没有兄弟可以提供一点建议。多谢。

当然,有其他更好的思路也欢迎share一下。

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
2 [报告]
发表于 2011-10-23 00:23 |只看该作者
gdb watch point

论坛徽章:
1
射手座
日期:2013-08-21 13:11:46
3 [报告]
发表于 2011-10-23 03:26 |只看该作者
如果是调试的话,就是楼上说的,下数据断点.
其实还有一种办法,就是用内存检测工具,比如valgrind,memcheck,把malloc/free之后的内存都fill特别的数字.
然后去看log,很详细的

论坛徽章:
0
4 [报告]
发表于 2011-10-23 05:24 |只看该作者
吐个槽:是魔鬼把magic number 翻译成魔鬼数字的吗?

论坛徽章:
0
5 [报告]
发表于 2011-10-24 13:46 |只看该作者
魔鬼数字亮了...
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP