调试器启动进程和附加进程的一点儿差别

当我们的程序出了问题,想要观察程序的执行过程,这时有两种进入调试的方式:

  • 附加到进程
  • 调试器启动进程

这是我们常用的两种方式,那么有什么差别呢?有差别,今天我就谈一点:那就是堆内存的不同。通过附加到进程的方式(排除用其他工具做了设置)内存是标准堆;而直接用调试器启动的方式内存是系统调试堆。

我们用Windbg来观察一下

直接启动进程

看到,直接启动进程进行调试,堆内存被做了很多设置:htc、hfc、hpc等

而附加的方式如下

可见少了很多设置项。

通过上面的差别,我们就明白了两种方式的同步。由于调试堆或多或少会影响性能,如果我们想不管哪种方式都想用标准堆,可以做如下设置:

  • 在系统环境变量里设置_NO_DEBUG_HEAP=1(这个是系统全局性,对任何调试器都可以禁止)
  • 如果是Windbg,可以在命令行使用 -hd选项
  • 如果是VS IDE,可以在项目属性里设置环境变量_NO_DEBUG_HEAP=1
    这个在VS2015以前的版本是管用的,2015及其以后的版本不需要了,已经自动禁止了

     

 

posted on 2022-07-11 15:03  活着的虫子  阅读(250)  评论(0编辑  收藏  举报

导航