我参与了您尝试生成尽可能小的二进制文件的挑战之一,因此我正在构建没有C 或 C++ 运行时库 (RTL) 的程序。我没有链接到 DLL 版本或静态版本。我什至没有#include
头文件。我有这个工作正常。
一些 RTL 函数,比如memset()
,可能很有用,所以我尝试添加自己的实现。它在 Debug 版本中运行良好(即使对于那些编译器生成隐式调用的地方memset()
)。但是在发布版本中,我收到一条错误消息,说我无法定义内在函数。您会看到,在 Release 版本中,内部函数已启用,并且memset()
是内部函数。
我很想memset()
在我的发布版本中使用内在函数,因为它可能是内联的,并且比我的实现更小、更快。但我似乎是第 22 条军规中的一员。如果我不定义memset()
,则链接器会抱怨它未定义。如果我定义了它,编译器会抱怨我不能定义一个内在函数。
有谁知道定义、声明、#pragma
编译器和链接器标志的正确组合,以在不增加 RTL 开销的情况下获得内在函数?
Visual Studio 2008、x86、Windows XP+。
为了使问题更具体一点:
extern "C" void * __cdecl memset(void *, int, size_t);
#ifdef IMPLEMENT_MEMSET
void * __cdecl memset(void *pTarget, int value, size_t cbTarget) {
char *p = reinterpret_cast<char *>(pTarget);
while (cbTarget > 0) {
*p++ = static_cast<char>(value);
--cbTarget;
}
return pTarget;
}
#endif
struct MyStruct {
int foo[10];
int bar;
};
int main() {
MyStruct blah;
memset(&blah, 0, sizeof(blah));
return blah.bar;
}
我这样构建:
cl /c /W4 /WX /GL /Ob2 /Oi /Oy /Gs- /GF /Gy intrinsic.cpp
link /SUBSYSTEM:CONSOLE /LTCG /DEBUG /NODEFAULTLIB /ENTRY:main intrinsic.obj
如果我使用 的实现进行编译memset()
,则会出现编译器错误:
error C2169: 'memset' : intrinsic function, cannot be defined
如果我在没有实现的情况下编译它memset()
,我会得到一个链接器错误:
error LNK2001: unresolved external symbol _memset