2013-04-11 51 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