调试器启动进程和附加进程的一点儿差别
当我们的程序出了问题,想要观察程序的执行过程,这时有两种进入调试的方式:
- 附加到进程
- 调试器启动进程
这是我们常用的两种方式,那么有什么差别呢?有差别,今天我就谈一点:那就是堆内存的不同。通过附加到进程的方式(排除用其他工具做了设置)内存是标准堆;而直接用调试器启动的方式内存是系统调试堆。
我们用Windbg来观察一下
直接启动进程
看到,直接启动进程进行调试,堆内存被做了很多设置:htc、hfc、hpc等
而附加的方式如下
可见少了很多设置项。
通过上面的差别,我们就明白了两种方式的同步。由于调试堆或多或少会影响性能,如果我们想不管哪种方式都想用标准堆,可以做如下设置:
- 在系统环境变量里设置_NO_DEBUG_HEAP=1(这个是系统全局性,对任何调试器都可以禁止)
- 如果是Windbg,可以在命令行使用 -hd选项
- 如果是VS IDE,可以在项目属性里设置环境变量_NO_DEBUG_HEAP=1
这个在VS2015以前的版本是管用的,2015及其以后的版本不需要了,已经自动禁止了