2013-04-11 4 views
5

Я воспроизвел поведение, которое я испытал в более крупном проекте, в следующих нескольких строках кода. Я отказался от охранников #ifndef и директив #include, чтобы улучшить читаемость. Ошибка компоновщика возникает при вызове make. Файл makefile включен в конце вопроса.weird undefined reference при связывании

Класс C наследует от B, который наследуется от A. 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; 
} 

И вот Makefile:

%.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

Что произойдет, если вы явно вызвать 'make mklibs', прежде чем пытаться скомпилировать основное приложение? –

ответ

3

Несколько раз порядок связи может быть важно, попробуйте -lO -lABC

+1

Угадав имена библиотек, это определенно причина. – 2013-04-12 00:10:48

Смежные вопросы