Powieliłem zachowanie, którego doświadczyłem w większym projekcie w kilku następnych wierszach kodu. Zostawiłem strażnikom #ifndef
i dyrektywom #include
, próbując poprawić czytelność. Błąd łączenia jest generowany podczas wywoływania make
. Plik makefile znajduje się na końcu pytania.Dziwne niezdefiniowane odniesienie podczas łączenia
Klasy C dziedziczą z B, który dziedziczy z A. O to zupełnie inna klasa.
Łącznik narzeka:
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&)'
Oto kod źródłowy. Starałem się, aby był tak mały i czytelny, jak to tylko możliwe. Masz pomysł, jaki jest problem?
/***** 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);
}
Oto główne:
/******* main.cpp *******/
int main()
{
A a;
O o;
o.foo(a);
return 0;
}
A oto 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] $^
Co się dzieje, jeśli wyraźnie powołać 'make mklibs' przed próbą skompilowania głównej aplikacji? –