Ich habe kürzlich versucht, meine Operatorüberladung/Template-Fähigkeiten zu messen und als kleinen Test die Container-Klasse unten erstellt. Während dieser Code gut kompiliert und unter MSVC 2008 korrekt funktioniert (zeigt 11 an), ersticken sowohl MinGW/GCC als auch Comeau die operator+
Überlastung. Da ich ihnen mehr als MSVC vertraue, versuche ich herauszufinden, was ich falsch mache. HierBinärer Operator überladen auf einer Vorlagenklasse
ist der Code:
#include <iostream>
using namespace std;
template <typename T>
class Container
{
friend Container<T> operator+ <> (Container<T>& lhs, Container<T>& rhs);
public: void setobj(T ob);
T getobj();
private: T obj;
};
template <typename T>
void Container<T>::setobj(T ob)
{
obj = ob;
}
template <typename T>
T Container<T>::getobj()
{
return obj;
}
template <typename T>
Container<T> operator+ <> (Container<T>& lhs, Container<T>& rhs)
{
Container<T> temp;
temp.obj = lhs.obj + rhs.obj;
return temp;
}
int main()
{
Container<int> a, b;
a.setobj(5);
b.setobj(6);
Container<int> c = a + b;
cout << c.getobj() << endl;
return 0;
}
Dies ist der Fehler Comeau gibt:
Comeau C/C++ 4.3.10.1 (Oct 6 2008 11:28:09) for ONLINE_EVALUATION_BETA2
Copyright 1988-2008 Comeau Computing. All rights reserved.
MODE:strict errors C++ C++0x_extensions
"ComeauTest.c", line 27: error: an explicit template argument list is not allowed
on this declaration
Container<T> operator+ <> (Container<T>& lhs, Container<T>& rhs)
^
1 error detected in the compilation of "ComeauTest.c".
Ich bin eine harte Zeit versucht, Comeau/MingGW zu bekommen, Ball zu spielen, so das ist, wo Ich wende mich an euch. Es ist lange her, dass mein Gehirn unter dem Gewicht der C++ - Syntax so stark geschmolzen ist, und ich fühle mich ein wenig peinlich berührt;).
BEARBEITEN: Beseitigt einen (irrelevanten) Lvalue-Fehler, der im ursprünglichen Comeau-Dump aufgelistet ist.
Ich denke, der Operator + ist eine Vorlagenfunktion, nicht wahr? Ein Container und ein Container werden zwei unterschiedliche Typen sein, so dass der Compiler zwei mit ihnen umgehen verschiedene Operator + Funktionen generieren müssen. Bedeutet das nicht, dass Operator + eine Template-Funktion ist? –
Es * ist * eine Funktionsvorlage. Aber Sie haben Recht, indem Sie das "<>" aus der Definition der Vorlage auslassen. („<>“ Wird nur verwendet, wenn eine Funktionsschablone * Angabe von * anrufen, und selbst dann ist nur notwendig, wenn eine Nicht-Template-Funktion mit dem gleichen Namen existiert.) –