Programme kompiliert in g ++ aber tritt mit Linker Fehler in gcc
Frage
Ich versuche, die Lösung zu einem Frage zu spezialisierten Template-Klassen .
Dieser Code mit einem kompiliert in g fein ++, sondern wirft Linker Fehler, wenn sie mit gcc kompiliert. Was ist die Ursache dieser Fehler?
$ g++ traits2.cpp
$ gcc traits2.cpp
/tmp/ccI7CNCY.o: In function `__static_initialization_and_destruction_0(int, int)':
traits2.cpp:(.text+0x36): undefined reference to `std::ios_base::Init::Init()'
traits2.cpp:(.text+0x3b): undefined reference to `std::ios_base::Init::~Init()'
/tmp/ccI7CNCY.o:(.eh_frame+0x11): undefined reference to `__gxx_personality_v0'
collect2: ld returned 1 exit status
Die traits2.ccp Datei, die die oben genannten Lösung mit einer emtpy main () Funktion:
#include <iostream>
using namespace std;
// A default Traits class has no information
template<class T> struct Traits
{
};
// A convenient way to get the Traits of the type of a given value without
// having to explicitly write out the type
template<typename T> Traits<T> GetTraits(const T&)
{
return Traits<T>();
}
template <int major, int minor> struct A
{
void f()
{
cout << major << endl;
}
};
// Specialisation of the traits for any A<int, int>
template<int N1, int N2> struct Traits<A<N1, N2> >
{
enum { major = N1, minor = N2 };
};
template <> struct A<4,0>
{
void f()
{
cout << "Specialized:" << GetTraits(*this).major << endl;
}
};
int main(int argc, char * argv[] )
{
/*
A<4,0> p;
A<1,2> p2;
p.f();
p2.f();
*/
return 1;
}
Lösung
Wenn Sie mit gcc kompilieren, die C ++ Bibliotheken sind nicht standardmäßig eingebunden. Immer baut C ++ Code mit g ++.
Andere Tipps
Wenn Sie selbst den Unterschied zu sehen, versuchen beiden Versionen mit der Option -v
$ g++ -v traits2.cpp
$ gcc -v traits2.cpp
Dies zeigt Ihnen die einzelnen Schritte von Code Top-ausführbare Datei, einschließlich der Bibliotheken, die hinzugefügt werden.
Der Code ist C ++, so dass es mit g ++ kompiliert werden muß, die C ++ Compiler, nicht gcc, die C-Compiler.