W projektach średniej wielkości lub nawet dużych złożone oddzielanie deklaracji i definicji szablonu jest przydatne w celu skrócenia czasu kompilacji.Co to jest niezawodna metoda specjalizacji szablonów w C++ dla oddzielnego nagłówka/źródła
Jednak w złożonym kodzie błędy małego programisty mogą prowadzić do niezauważonej zmiany zachowania, np. np. zamiast specjalizacji wywoływana jest wersja ogólna.
Przykład: Specjalizacja szablonów stała się niewidoczna z powodu nieodebranego zgłoszenia.
///////////////////// file A.hpp /////////////////////
#include <iostream>
template <typename T>
class A
{
public:
void foo()
{
std::cerr << " calling generic foo " << std::endl ;
}
};
// forgetting following declaration leads to an unintended program behaviour
template <> void A<int>::foo();
///////////////////// file A-foo-int.cpp /////////////////////
#include "A.hpp"
template <>
void A<int>::foo()
{
std::cerr << "calling <int> version of foo" << std::endl;
}
///////////////////// file main.cpp /////////////////////
#include "A.hpp"
int main(int argc , char** argv)
{
A<int>* a = new A<int>();
a->foo();
return 0;
}
///////////////////// Makefile /////////////////////
CC = g++
CPPFLAGS += -Wall -O3
CXXFLAGS += --std=gnu++0x
all: nonrobust-template-setup
nonrobust-template-setup: main.o A-foo-int.o
$(CC) $(CPPFLAGS) main.o A-foo-int.o -o nonrobust-template-setup
clean:
rm -rf *.o nonrobust-template-setup
//////////////////////////////////////////
Pytanie: jest bardziej wytrzymała konfiguracji możliwe (compiler- i niezależny od platformy) i jeśli, jak to będzie wyglądać?
Jeśli nie, jaki jest dobry sposób na sprawdzenie, czy wybrana jest pożądana wersja funkcji?
Myślę, że robisz wszystko, co powinieneś. Tak po prostu działa w C++ :) – cubuspl42