Programas compila em g ++, mas sai com erros vinculador em gcc
Pergunta
Eu estou tentando o solução a um pergunta sobre classes de modelo especializados .
Este código com uma multa compila em g ++, mas joga-se erros de vinculador quando compilado com gcc. Qual é a causa desses erros?
$ 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
O arquivo traits2.ccp contém o referido solução com uma função 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;
}
Solução
Quando você compilar com gcc, as bibliotecas C ++ não são ligados por padrão. Sempre construir código C ++ com g ++.
Outras dicas
Se você quiser ver a diferença para si mesmo, tente ambas as versões com o sinalizador -v
$ g++ -v traits2.cpp
$ gcc -v traits2.cpp
Isto irá mostrar cada um dos passos da top código executável, incluindo as bibliotecas que são adicionadas.
Seu código é C ++, por isso deve ser compilado com g ++, o compilador C ++, não gcc, o compilador C.