c++ - 将静态 C 库与 C++ 代码链接时出现 "undefined reference to"错误

标签 c++ c static-libraries

我有一个测试文件(仅用于链接测试),我在其中重载了 new/delete我自己的运营商malloc/free名为 libxmalloc.a 的库.但是在链接静态库时,我不断收到“ undefined reference ”错误,即使我更改了 test.o 的顺序和 -lxmalloc .但是一切都适用于链接这个库的其他 C 程序。我对这个问题感到很困惑,并感谢任何线索。

错误信息:

g++ -m64 -O3 -I/usr/include/ethos -I/usr/include/nacl/x86_64 -c -o test.o test.cpp
g++ -m64 -O3 -L. -o demo test.o -lxmalloc
test.o: In function `operator new(unsigned long)':
test.cpp:(.text+0x1): undefined reference to `malloc(unsigned long)'
test.o: In function `operator delete(void*)':
test.cpp:(.text+0x11): undefined reference to `free(void*)'
test.o: In function `operator new[](unsigned long)':
test.cpp:(.text+0x21): undefined reference to `malloc(unsigned long)'
test.o: In function `operator delete[](void*)':
test.cpp:(.text+0x31): undefined reference to `free(void*)'
test.o: In function `main':
test.cpp:(.text.startup+0xc): undefined reference to `malloc(unsigned long)'
test.cpp:(.text.startup+0x19): undefined reference to `malloc(unsigned long)'
test.cpp:(.text.startup+0x24): undefined reference to `free(void*)'
test.cpp:(.text.startup+0x31): undefined reference to `free(void*)'
collect2: ld returned 1 exit status
make: *** [demo] Error 1

我的test.cpp文件:

#include <dual/xalloc.h>
#include <dual/xmalloc.h>
void*
operator new (size_t sz)
{
    return malloc(sz);
}
void
operator delete (void *ptr)
{
    free(ptr);
}
void*
operator new[] (size_t sz)
{
    return malloc(sz);
}
void
operator delete[] (void *ptr)
{
    free(ptr);
}
int
main(void)
{
    int *iP = new int;
    int *aP = new int[3];
    delete iP;
    delete[] aP;
    return 0;
}

我的Makefile :

CFLAGS += -m64 -O3 -I/usr/include/ethos -I/usr/include/nacl/x86_64
CXXFLAGS += -m64 -O3
LIBDIR += -L.
LIBS += -lxmalloc
all: demo
demo: test.o
    $(CXX) $(CXXFLAGS) $(LIBDIR) -o demo test.o $(LIBS)
test.o: test.cpp
$(CXX) $(CFLAGS) -c -o $@ $<
clean:
- rm -f *.o demo

最佳答案

But everything works well with other C programs linking this library.

您是否注意到 C 和 C++ 编译在目标文件级别创建不同的符号名称?它被称为' name mangling '。
(C++) 链接器会在错误消息中将 undefined reference 显示为解构符号,这可能会让您感到困惑。如果您使用 nm -u 检查您的 test.o 文件,您会发现引用的符号名称与库中提供的名称不匹配。

如果您想将链接的函数用作使用普通 C 编译器编译的外部函数,您需要将它们的函数声明包含在一个抑制 C++ 名称的 extern "C"{} block 中修改内部声明或定义的所有内容,例如:

extern "C" 
{
    #include <dual/xalloc.h>
    #include <dual/xmalloc.h>
}

更好的是,您可以将函数声明包装在头文件中,如下所示:

#if defined (__cplusplus)
extern "C" {
#endif

/*
 * Put plain C function declarations here ...
 */ 

#if defined (__cplusplus)
}
#endif

关于c++ - 将静态 C 库与 C++ 代码链接时出现 "undefined reference to"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18877437/

相关文章:

c++ - 在析构函数中调用观察者是不好的做法吗?

c++ - 从 qmake 运行脚本以获取内部版本号

c - 如何在我的代码中实现 #define 语句?

c++ - 如何在 Linux (Ubuntu) 中使用 FreeImage 库静态编译 C/C++ 应用程序?

c++ - 在 Windows 上分发( native C++)库

c++ - 模板类中模板函数的困难

c++ - 使用 opencv 和 c++ 找到最接近复杂形状的匹配项的最佳方法是什么?

C Unix 毫秒定时器返回差值 0

c - 如何检索存储在无符号变量中的有符号值

ios - 为 Xcode 4 创建跨项目引用时遇到问题