在VS的有.net版本 以后增加了可以在调试过程中动态改变逻辑代码的功能,也就是/EDITANDCONTINUE。这个功能的原理在于调试时将所有函数的起始地址放到一个ILT(incremental link table)内存中,这样每个函数修改时不会影响到其它函数的地址或者说影响的机会很小。
可以做实验,默认情况,VS写一个简单的C++程序,添加一个全局函数,然后用printf打印函数地址,再用反汇编代码下到那个函数地址的位置看会是很多个jmp指令。
编译器提供了/INCREMENTAL连接命令控制增量连接,代码中可以用
#pragma comment(linker, "/INCREMENTAL:NO")
直接禁止增量连接,再用刚才的方法编译看到的结果将是不一样的,并且此时EDITANDCONTINUE功能也会被禁用。
关于在Debug模式下查找函数的真实地址,请看我的另一篇《VC中获取函数的真实地址 》