gpt4 book ai didi

delphi - 如何使用 Win32 调试 API 实现代码覆盖工具

转载 作者:行者123 更新时间:2023-12-03 18:29:48 25 4
gpt4 key购买 nike

我试图了解如何使用 Win32 调试 API 实现代码覆盖率工具。

我的想法是使用 Win32 Debugging API在 Debug模式下启动进程 - 并跟踪已执行的 CPU 指令。在跟踪所有 CPU 指令后,我将使用映射文件将其映射到执行的源代码行。

据我了解,有两种方法可以知道 CPU 指令正在执行。

  • 将以 Debug模式启动进程 - 将所有线程设置为单步模式并让调试应用记录所有已执行的指令
  • 将是一种更智能的方法,您将更多地了解 x86 指令,并基本上用断点替换下一条分支指令。然后跟踪两个断点之间的增量指令。

  • 更新 - 受迈克尔回复启发的新建议方法:
  • 从映射文件开始,在每一行的开头插入断点,让调试框架在每次断点命中时得到通知。
  • 从映射文件开始 - 二进制工具插入在每个源代码行的入口处调用的“钩子(Hook)” - 避免通过调试器框架进行回调。
  • 使用 VM 技术 - 例如 VMware 来找出特定进程中执行了哪些指令 - 我不完全理解这种方法...

  • 有人可以验证上述方法之一,或者建议替代方法 - 请注意,用例是逐行代码覆盖而不是性能分析 - 因此我们需要知道是否访问了每个单独的源代码行。

    我的主要目标(虽然没有具体的计划......)主要是为 Delphi 创建一个简单的代码覆盖工具。

    谢谢!

    最佳答案

    一种方法是 Hook 所有 api 调用和函数调用以与从源生成的表进行比较。因此,您会发现所涵盖的内容。
    hooking的api有很多,一个是Trappola API hooking

    关于delphi - 如何使用 Win32 调试 API 实现代码覆盖工具,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/726476/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com