У меня есть рабочий код, похожий на этот.Явный экземпляр шаблона C++
#include <iostream>
struct A{
template<typename T>
void foo(T val);
};
template<typename T> void A::foo(T val)
{
std::cout << val << std::endl;
}
// link template "against" int
template void A::foo(int val);
// #include header here
int main(){
A a;
a.foo(12);
}
Шаблон находится в отдельном файле CPP, но связывающие работы, из-за явного конкретизации:
template void A::foo(int val);
Тогда я сделал некоторые рефакторинга, и код выглядит следующим образом:
#include <iostream>
template<typename G>
struct A{
template<typename T>
void foo(T val);
};
template<typename G>
template<typename T> void A<G>::foo(T val)
{
std::cout << val << std::endl;
}
// link template "against" int - not working
//template<typename G>
//template void A<G>::foo(int val);
int main(){
A<float> a;
a.foo(12);
}
Как я могу «связать» T = int, но сохранить G «неизвестно»?
@ Ник да, синтаксис довольно сложный в таком случае. См. Https://gist.github.com/artemkin/61d919c6da3fa2d63833 – Stas