zoukankan      html  css  js  c++  java
  • Debugging Beyond Visual Studio – WinDbg

    Getting started with WinDbg:

    1. Download the Debugging Tools for Windows from the Microsoft website

    We recommend you install WinDbg Preview as it offers more modern visuals, faster windows, a full-fledged scripting experience, built with extensible debugger data model front and center.

    clip_image001

    2. When clicking Download from the Microsoft Store, a prompt will appear, select “Get”

    clip_image003

    3. Windows will start the download and installation process. A prompt will confirm installation status.

    clip_image004

    4. Select to “Pin to Start,” close windows by clicking “X” on the top right of Window.

    clip_image006

    5. Set the Windows Symbol Server path in File > Settings > Symbol path (see example below)

    clip_image008

    6. Go to your Start menu, select the WinDbg Preview to launch the application

    7. The WinDbg initial view

    clip_image010

    8. What is the difference between User Mode-Debugging and Kernel-Mode Debugging?

    In User mode debugging, the code normally delegates to the system API’s to access hardware or memory. You typically are debugging a single executable, which is separated from other executables by the OS. Typical scenario is to isolate memory or application hang issues on Win32 desktop applications. In User mode, the debugger is running on the same system as the code being debugged.

    In Kernel mode debugging, the code normally has unrestricted access to the hardware. Typical scenario is driver code developed for hardware devices. When debugging in Kernel mode you typically use two different systems. One system runs the code that is being debugged, and another runs the debugger, usually connected with a cable. Click here for additional information on Kernel mode debugging.

    9. Advantages of WinDbg:

    • Extensive numbers of commands and extensions.
    • A useful tool to help understand OS and software running on the system being debugged.
    • Lightweight and can be used in production as it has no dependency, only require an executable (.exe) to run.
    • A useful tool to help isolate User or Kernel mode code that's difficult to troubleshoot on Windows.

    10. Common User mode debugging commands:

    .hh (Open WinDbg’s help)

    clip_image012

    Vertaget (Get the version of the target computer)

    clip_image014

    Symbol Path (Display or set symbol search path)

    clip_image016

    Version (Dump version info of debugger and loaded extension DLLs)

    clip_image018

    !ext.help(General extensions)

    clip_image020

    !analyze -v (Display information about the current exception or bug check; verbose)

    clip_image022

    11. Common Kernel mode debugging commands:

    !analyze

    clip_image024

    !error (plus error code, e.g. “!error c0000005)

    clip_image026

    12. Useful links:

    Debugging Using WinDbg Preview:

    https://docs.microsoft.com/en-us/windows-hardware/drivers/debugger/debugging-using-windbg-preview

    Getting Started with WinDbg Microsoft Docs:

    https://docs.microsoft.com/en-us/windows-hardware/drivers/debugger/getting-started-with-windbg

    Common WinDbg Commands:

    http://windbg.info/doc/1-common-cmds.html

    Elementary User-Mode Debugging:

    https://microsoft.sharepoint.com/teams/bidpwiki/Pages1/Elementary%20User-Mode%20Debug.aspx

  • 相关阅读:
    移动端调试Vconsole
    Vue-返回顶部
    Vue-封装loading
    Vue-水印封装
    Vue-封装scroll触底
    微信小程序-图片上传
    前端面试题(2)
    前端常见面试题
    服务端渲染(SSR)和客户端(CSR)渲染的区别
    什么是模块化?模块化开发的好处
  • 原文地址:https://www.cnblogs.com/Javi/p/9065840.html
Copyright © 2011-2022 走看看