欢迎光临 高端调试
登录
|
注册
|
FAQ
搜索论坛
内核调试
ACPI调试
Linux内核调试
Windows内核调试
调试方法学
调试战役
调试原理
新工具观察
操作系统
Linux
Windows Vista
Windows
驱动开发
Linux驱动
WDF
WDM
总线
PCI Express
PCI/PCI-X
USB
无线通信协议
中央处理器
64位CPU
ARM
IA-32
CPU Info Center
计算机机系统
ACPI标准
系统认证
Desktop
服务器
嵌入式系统
Embedded Linux
嵌入式开发工具
VxWorks
WinCE
嵌入式Windows
特别链接
格蠹调试套件(GDK)
格蠹学院
小朱书店
老雷的微博
《软件调试》
《格蠹汇编》
《软件调试(第二版)》
沪ICP备11027180号-1
C/C++本地代码调试
帖子发起人:
chena_cpp
发起时间:
2013-10-10 21:30 下午
回复:
3
高端调试
»
软件调试
»
C/C++本地代码调试
»
Re: 内存块的gap被改写,求思路。
搜索论坛
帖子排序:
Oldest to newest
Newest to oldest
2013-10-10, 21:30 下午
chena_cpp
注册: 2012-12-21
发 贴: 11
内存块的gap被改写,求思路。
struct A
{
......
wstring a;
wstring b;
......
};
vector<A *> a;
程序启动的时候,初始化a,vector的size是240。
经过一定步骤之后,退出程序,删除a,在delete其中一个A *(v0)的时候,crt报错。
我查看内存,发现v0->b的内存块后面是FD FD FD 00,我分析是有野指针写入最后一个字节。
如果v0是固定的索引,比如每次都是第40个,那么可以在初始化的时候给v0->b内存块的gap最后一个字节设一个内存断点。
但每次这个索引都是随机的,不过每次都是这个vector里的string出错。
有办法找到什么时候写入的吗?
IP 地址: 已记录
报告
2013-10-13, 08:38 上午
Blade
注册: 2013-07-04
发 贴: 28
Re: 内存块的gap被改写,求思路。
你是不是有跨模块释放内存, 也就是在A模块中申请的内存到B模块中释放, 这样会出问题的, 因为不同模块的Heap是相互独立的 (/M 方式编译), 跨模块释放是不允许的。 因为我碰到过几次string 出问题, 都是因为这个原因引起的, 所以想你会不会也是因为这个原因。
如果要打硬件断点的话需要指定地址吧? 要不你把vector的 size设置小一点, 然后在每个索引下的 gap位置都打上断点?
IP 地址: 已记录
报告
2013-10-15, 06:59 上午
格蠹老雷
注册: 2005-12-19
发 贴: 1,303
Re: 内存块的gap被改写,求思路。
也可以尝试页堆
IP 地址: 已记录
报告
2013-10-27, 13:42 下午
哈姆雷特
注册: 2013-08-26
发 贴: 1
Re: 内存块的gap被改写,求思路。
附件:
pageheap.JPG
有两条思路:
1. 张老师说的应该是应用程序验证器(Windows Application Verifier),启用full page heap。这个工具可以在内存写越界时中断到调试器。http://www.microsoft.com/downloads/details.aspx?FamilyID=c4a25ab9-649d-4a1b-b4a7-c9d8b095df18&DisplayLang=en&displaylang=en
2. 按照楼上说的,可能有跨模块的分配释放。为了确认的话,可以跟踪对象的分配和释放的时候是否用了同一个heap handle.
IP 地址: 已记录
报告
高端调试
»
软件调试
»
C/C++本地代码调试
»
Re: 内存块的gap被改写,求思路。
请选择
论坛首页
|- 论坛搜索
|- 热门主题
|- 未回复的主题
用户选项
|- 登录
|- 注册
|- 找回密码
软件调试
|- Windows内核调试
|- C/C++本地代码调试
|- .Net程序调试
|- 脚本程序调试
|- Java程序调试
|- Linux内核调试
|- 《程序员》杂志调试专栏
|- WinDbg
|- GDB
|- 远程调试
|- 调试ACPI和BIOS
|- 特殊的调试任务
|- 转储分析
|- GDK7
内核探秘
|- Windows内核
|- Linux内核
系统架构
|- CPU架构
|- PCI/PCI Express架构
程序人生
|- 软件物语
|- 社区活动
|- 名人逸事
联盟论坛
|- 欢迎使用CnForums
没有银弹
|- BUG也精彩
|- 豆腐工程
|- 软件圈里十大怪
Windows Vista
|- 用调试利剑剖析VISTA内幕
|- 老专家如何破解新问题
|- 我的电脑谁说了算?
|- 资源
Office开发
|- Visio
驱动程序开发
|- Windows驱动开发
|- Linux驱动开发
|- Windows CE驱动开发
用户态开发
|- Windows本地代码(native)高级开发
|- Web应用开发
|- WinFX和.Net
|- Office开发
本站建设
|- 高端调试团队
|- 版面布局
|- 活动建议
|- 网站维护
64位计算
|- 64-bit Windows
|- 64-bit CPU
图书
|- 《软件调试》的示例程序
|- 《软件调试》的工具
|- 《软件调试》书友
|- 《软件调试》答疑
|- 《软件调试》勘误和意见
|- 《格蠹汇编》
|- 《软件调试》第二版卷1
|- 《软件调试》第二版卷2
云计算
|- IaaS
|- 云存储
|- 大数据
|- PaaS和SaaS
GPU
|- CUDA
|- OpenCL
|- HSA
|- 游戏开发与调试
(C)2004-2020 ADVDBG.ORG All Rights Reserved.