I programmi vengono compilati in g ++ ma escono con errori del linker in gcc
Domanda
Sto provando soluzione in una domanda sulle classi di template specializzate .
Questo codice con una compilazione va bene in g ++, ma genera errori del linker quando compilato con gcc. Qual è la causa di questi errori?
$ 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
Il file traits2.ccp contiene i suddetti soluzione con una funzione emtpy main ():
#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;
}
Soluzione
Quando compili con gcc, le librerie C ++ non sono collegate per impostazione predefinita. Crea sempre il codice C ++ con g ++.
Altri suggerimenti
Se vuoi vedere la differenza da solo, prova entrambe le versioni con il flag -v
$ g++ -v traits2.cpp
$ gcc -v traits2.cpp
Questo ti mostrerà ciascuno dei passaggi dell'eseguibile in cima al codice, comprese le librerie che sono state aggiunte.
Il tuo codice è C ++, quindi deve essere compilato con g ++, il compilatore C ++, non gcc, il compilatore C.