【发布时间】:2015-03-24 12:50:25
【问题描述】:
在现有项目中遇到此代码,其中包括在进程中注入 DLL 并从那里进行操作。
他们声明了一些函数指针的偏移量,然后他们遍历它们以添加特定的 dll 偏移量。
我无法通过宏定义的函数进行迭代。如果我只有 5-6 个函数,它似乎可以正常工作,但是当我添加更多时它就不起作用了。
#pragma optimize ( "", off )
#define DLLOFFSET(a1,b1) ((DLLNO_##a1)|((b1)<<8))
#define FUNCPTR(d1,v1,t1,t2,o1) typedef t1 d1##_##v1##_t t2; d1##_##v1##_t *d1##_##v1 = (d1##_##v1##_t *)DLLOFFSET(d1,o1);
#define ASMPTR(d1,v1,o1) DWORD d1##_##v1 = DLLOFFSET(d1,o1);
#define _PTRS_START PREFIX1_aaa
...
FUNCPTR(PREFIX1, aaa, ....., 0xFFFFF)
...
FUNCPTR(PREFIX3, fff, ....., 0xFFFFF)
...
FUNCPTR(PREFIX2, ggg, ....., 0xFFFFF)
...
ASMPTR(PREFIX1, jjj, 0xFFFFF)
...
#define _PTRS_END PREFIX1_jjj
void DefineOffsets()
{
DWORD *p = (DWORD *)&_PTRS_START;
do {
*p = "call update pointer function here"
} while(++p <= (DWORD *)&_PTRS_END);
}
#pragma optimize( "", on )
如果只定义了几个函数,那么循环就可以正常工作。但是,当有很多时,编译器似乎不会将代码全部放在一个块中。因此,为什么我们不能通过增加指针来循环它们。
我通过复制函数并声明一个新数组找到了另一种方法,但我宁愿不必在两个文件中维护相同的代码。
项目的一位程序员说他有同样的问题,他通过从项目->属性->c++->优化->禁用中删除项目优化来修复它。
我试过了。也试过project->properties->c++->Code gen->Enable minimum build->No.
我正在使用 vs 2012。
【问题讨论】:
-
宏不是“函数”。无论您真正在做什么,如果它可以通过七个扩展而不是更少的扩展来重现,请提供一个 真正 七个扩展 oomplete 示例来展示您提到的问题,以及编译器或链接器生成的任何错误消息。或许还要澄清一下“不要把代码全部放在一块”是什么意思。
-
@WhozCraig 感谢您将讨论保持在精英级别。
标签: c++ c-preprocessor