关于程序崩溃后dmp简易分析的一点收获

2024-04-26 19:48

本文主要是介绍关于程序崩溃后dmp简易分析的一点收获,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近出现一个托盘文件在一台XP SP3实体机上偶尔崩溃的现象,以前从未接触过此类问题解决,求助于同事,才初步有了点处理的知识。


准备工具列表:

userdump.exe   pid   \\用来手动获取当前崩溃的dmp文件,后面的pid可从进程管理器获得,比如xxx.exe

                                       运行后,将生成xxx.dmp

windbg              用于分析dmp文件,本人目前只懂得一点皮毛。

                           首先就是设置进制文件对应的pdb 和源文件路径。然后载入dmp文件。

                           然后!analyze -v 显示出自动分析的结果。

                           在结果中找到如类似的文字,表示错误位置如:

STACK_TEXT:  

WARNING: Stack unwind information not available. Following frames may be wrong.

0012fd5c 0041bce6 0017a688 00000000 00000000 ntdll!KiFastSystemCallRet

0012fda0 0041afb4 00000004 2a84b1cd 005b8ed8 VpnTray+0x1bce6

0012fdec 00401176 2a84b1d9 005b8ed8 00000000 VpnTray+0x1afb4

0012ff1c 00548ea8 fffffffe 00000000 00000001 VpnTray+0x1176

0012ff30 00515595 00400000 00000000 000207a4 VpnTray+0x148ea8

0012ffc0 7c817067 80000001 0012ef50 7ffde000 VpnTray+0x115595

0012fff0 00000000 00515600 00000000 78746341 kernel32!RegisterWaitForInputIdle+0x49


然后就使用

u    VpnTray+0x115595 计算出该入口的对应内存偏移位置,

使用下面工具进一步分析。


idag                  刚接触,暂时认为是反汇编的工具吧,载入exe文件后,使用键盘 G 弹出输入地址的对话框,键入刚才找到的地址,就将弹出汇编代码

                          如:

                         loc_515588:             ; nCmdShow

push    ecx

push    eax             ; lpCmdLine

push    esi             ; hPrevInstance

push    offset ___safe_se_handler_count ; hInstance

call    _wWinMain@16    ; wWinMain(x,x,x,x)

mov     [ebp+mainret], eax

cmp     [ebp+managedapp], esi

jnz     short $LN36_9   ; $LN36

然后就可以慢慢找崩溃的函数位置。


今后还需进一步学习



                            

这篇关于关于程序崩溃后dmp简易分析的一点收获的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/938503

相关文章

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

MOLE 2.5 分析分子通道和孔隙

软件介绍 生物大分子通道和孔隙在生物学中发挥着重要作用,例如在分子识别和酶底物特异性方面。 我们介绍了一种名为 MOLE 2.5 的高级软件工具,该工具旨在分析分子通道和孔隙。 与其他可用软件工具的基准测试表明,MOLE 2.5 相比更快、更强大、功能更丰富。作为一项新功能,MOLE 2.5 可以估算已识别通道的物理化学性质。 软件下载 https://pan.quark.cn/s/57

EMLOG程序单页友链和标签增加美化

单页友联效果图: 标签页面效果图: 源码介绍 EMLOG单页友情链接和TAG标签,友链单页文件代码main{width: 58%;是设置宽度 自己把设置成与您的网站宽度一样,如果自适应就填写100%,TAG文件不用修改 安装方法:把Links.php和tag.php上传到网站根目录即可,访问 域名/Links.php、域名/tag.php 所有模板适用,代码就不粘贴出来,已经打

衡石分析平台使用手册-单机安装及启动

单机安装及启动​ 本文讲述如何在单机环境下进行 HENGSHI SENSE 安装的操作过程。 在安装前请确认网络环境,如果是隔离环境,无法连接互联网时,请先按照 离线环境安装依赖的指导进行依赖包的安装,然后按照本文的指导继续操作。如果网络环境可以连接互联网,请直接按照本文的指导进行安装。 准备工作​ 请参考安装环境文档准备安装环境。 配置用户与安装目录。 在操作前请检查您是否有 sud

跨系统环境下LabVIEW程序稳定运行

在LabVIEW开发中,不同电脑的配置和操作系统(如Win11与Win7)可能对程序的稳定运行产生影响。为了确保程序在不同平台上都能正常且稳定运行,需要从兼容性、驱动、以及性能优化等多个方面入手。本文将详细介绍如何在不同系统环境下,使LabVIEW开发的程序保持稳定运行的有效策略。 LabVIEW版本兼容性 LabVIEW各版本对不同操作系统的支持存在差异。因此,在开发程序时,尽量使用

线性因子模型 - 独立分量分析(ICA)篇

序言 线性因子模型是数据分析与机器学习中的一类重要模型,它们通过引入潜变量( latent variables \text{latent variables} latent variables)来更好地表征数据。其中,独立分量分析( ICA \text{ICA} ICA)作为线性因子模型的一种,以其独特的视角和广泛的应用领域而备受关注。 ICA \text{ICA} ICA旨在将观察到的复杂信号

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

【软考】希尔排序算法分析

目录 1. c代码2. 运行截图3. 运行解析 1. c代码 #include <stdio.h>#include <stdlib.h> void shellSort(int data[], int n){// 划分的数组,例如8个数则为[4, 2, 1]int *delta;int k;// i控制delta的轮次int i;// 临时变量,换值int temp;in