编译器优化合并了相同的函数实现,这意味着在运行时要绕过存根
Compiler optimization merge identical functions implementation meant to be stubs to be detoured during runtime
我有一个C++测试项目,其中包含一组具有相同实现的存根函数。这些存根将在运行时使用Windows Detours进行"替换"。问题是,在发布模式下,编译器会使所有这些存根指向同一个实现。为了说明这一点,请考虑以下代码:
#include <iostream>
using namespace std;
void A() { cout << "stub" << endl; }
void B() { cout << "stub" << endl; }
void main()
{
cout << &A << ", " << &B << endl;
}
在调试模式下,指针值将不同。在释放模式下,它们是相同的。我尝试了pragma优化指令(我使用的是Microsoft编译器),但它没有解决问题。结果,我的Windows Detours钩子拦截了对相同存根的所有调用。
我该怎么解决这个问题?谢谢
尝试使用预处理器宏使存根函数唯一,这样优化器就不会将它们合并为一个函数。
__FILE__、__LINE_和__FUNCTION_在C++中的使用
类似这样的东西:
void A() { cout << __FUNCTION__ << endl; }
void B() { cout << __FUNCTION__ << endl; }
相关文章:
- CMake-按正确顺序将项目与C运行时对象文件链接
- 我在c++代码中生成了一个运行时#3异常
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- 删除指向指针的指针是运行时错误吗
- 如何用参数值调用函数(仅在运行时已知)
- 为什么即使使用-cudart-static进行编译,库用户仍然需要链接到cuda运行时
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- c++中的指针和运行时错误
- 在运行时处理类型擦除的数据-如何不重新发明轮子
- 有没有一种方法可以测量c++程序的运行时内存使用情况
- 建议在运行时将带有类实例的列表从c++导入qml
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 如何在GTK程序运行时禁用屏幕保护程序/电源管理/屏幕消隐
- 在同一模拟中使用静脉和静脉_ inet内容时出现运行时错误
- 读取文件时运行时的未知行为
- 函数在Windows或Linux上运行时表现不同
- 在声明中合并两个常量"std::set"(不是在运行时)
- 非类型引用参数可以在运行时修改,这是否意味着模板可以在运行时实例化?
- 编译器优化合并了相同的函数实现,这意味着在运行时要绕过存根
- 当我的应用程序无法在调试模式下运行,但 exe 文件可以完美运行时,这意味着什么?