2013-04-11 29 views
5

我在以下几行代码中重现了我在更大项目中遇到的行为。我忽略了#ifndef卫士和#include指令,试图提高可读性。链接器错误是在调用make时产生的。该问题的最后包含makefile。连接时出现奇怪的未定义参考

C类从继承自B的B继承而来.O是一个完全不同的类。

链接器抱怨:

g++ -o main main.cpp -L. -lABC -lO 
./libO.a(O.o): In function `O::foo(A)': 
O.cpp:(.text+0x1f): undefined reference to `C::C(A const&)' 

这里的源代码。我试图让它尽可能小而且可读。任何想法是什么问题?

/***** A.h *****/ 
class A 
{ 
    public: 
    A(); 
    A(const A& a); 
}; 

/***** A.cpp *****/ 
A::A() {} 
A::A(const A& a) {} 

/****** BC.h *******/ 
class B : public A 
{ 
    public: 
    B(const A& a); 
}; 

class C : public B 
{ 
    public: 
    C(const A& a); 
}; 

/******* BC.cpp ********/ 
B::B(const A& a) : A(a) {} 
C::C(const A& a) : B(a) {} 

/***** O.h *****/ 
class O 
{ 
    public: 
    void foo(A a); 
}; 

/***** O.cpp *****/ 
void O::foo(A a) 
{ 
    C c(a); 
} 

这里的主:

/******* main.cpp *******/ 
int main() 
{ 
    A a; 
    O o; 
    o.foo(a); 
    return 0; 
} 

而这里的生成文件:

%.o: %.cpp %.h 
    g++ -c $< 

.PHONY: all 
all: mklibs main 

main: main.cpp 
    g++ -o [email protected] main.cpp -L. -lABC -lO 

mklibs: libABC.a libO.a 

libABC.a: A.o BC.o 
    ar -r [email protected] $^ 

libO.a: O.o 
    ar -r [email protected] $^ 
+0

如果明确调用会发生什么在尝试编译主应用程序之前使'mklibs'成为可能? –

回答

3

有时候链接顺序也很重要,尽量-lO -lABC

+1

从图书馆的名字猜测,这绝对是原因。 – 2013-04-12 00:10:48