Meine aktuellen Code sieht aus wie folgt: Code hereWie erhält man die innere Template-Klasse zum Typ der äußeren Template-Klasse?
Ich habe eine Vorlage ClassOuter
und eine verschachtelte Vorlage ClassInnerBase
, wo TypeD
von jeder Art von TypeA, TypeB, TypeC
und kein anderer sein kann. Desweiteren sollte von ClassInnerBase
erben und die virtual const int Method(int id) = 0;
implementieren.
template<typename TypeA, typename TypeB, typename TypeC>
class ClassOuter {
public:
class ClassInnerBase {
public:
ClassInnerBase(int x) :
m_x(x) {
}
virtual const int Method(int id) = 0;
private:
int m_x;
};
template<typename TypeD>
class ClassInnerDerived : public ClassInnerBase {
public:
ClassInnerDerived<TypeD>(const TypeD &object, int x) :
ClassInnerBase(x), m_object(object) {
}
// Implementation of ClassInnerBase::Method for type float
template<>
const int ClassInnerDerived<float>::Method(int id){
return GetLookupID(id);
}
// Implementation of ClassInnerBase::Method for type double
template<>
const int ClassInnerDerived<double>::Method(int id){
return GetLookupID(id);
}
private:
TypeD m_object;
};
void DoSomething(const std::vector<ClassInnerBase> &inner_vec, int id);
const int GetLookupID(int id) const{
return lookup[id];
}
private:
int lookup[100];
};
template<typename TypeA, typename TypeB, typename TypeC>
void ClassOuter<TypeA, TypeB, TypeC>::DoSomething(const std::vector<ClassInnerBase> &inner_vec, int id){
for(const auto &inner : inner_vec){
inner.Method(id);
}
}
int main()
{
std::vector<typename ClassOuter<int, double, float>::ClassInnerBase> class_base_objects;
typename ClassOuter<int, double, float>::template ClassInnerDerived<float> class_inner_derived_object(0.2f, 1);
class_base_objects.push_back(class_inner_derived_object);
typename ClassOuter<int, double, float>::template DoSomething(class_base_objects, 1);
}
ich am Ende der Fehler bekommen:
g++ -std=c++14 -O2 -Wall -pedantic -pthread main.cpp && ./a.out
main.cpp:30:18: error: explicit specialization in non-namespace scope 'class ClassOuter<TypeA, TypeB, TypeC>::ClassInnerDerived<TypeD>'
template<>
^
Ich bin hier ganz fest und weiß nicht, wie diese Fehler zu beheben. Gibt es auch irgendwelche Vorschläge/Kommentare/Verbesserungen zur Implementierung?
Sie wäre besser, besser auf [Code Review] (http://codereview.stackexchange.com/) für Verbesserungen an Ihrer Implementierung – Rakete1111
@ Rakete1111 Nein, Code Review ist * nicht * ein Ort für kaputten Code, da es außerhalb des Themas da drüben ist. Er fragte auf der richtigen Seite. – syb0rg
@ syb0rg Ich meinte nur das Verbesserungsbit. Für den eigentlichen Fehler ist OP auf der richtigen Seite – Rakete1111