oli83 Geschrieben 13. Juni 2005 Teilen Geschrieben 13. Juni 2005 Hi. Ich habe eine Klasse mit einem ifstream-Objekt deklariert. Im Konstruktur soll ein ifstream-Objekt zur Initialisierung übergeben werden. Ich erhalte dabei jedoch folgende Fehlermeldung: error C2582: 'std::basic_ifstream<char,struct std::char_traits<char> >' : 'Operator =' ist nicht verfuegbar . wie kann ich das Problem mit der Initialisierung lösen? #include <fstream> using namespace std; class Tupel { public: Tupel(ifstream file); // Konstruktor ~Tupel(); // Destruktor ifstream inFile; }; #include "lowercase.h" Tupel::Tupel(ifstream file) { inFile = file; } Tupel::~Tupel() { } Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Klotzkopp Geschrieben 13. Juni 2005 Teilen Geschrieben 13. Juni 2005 Streamobjekte sind nicht kopierbar (man sagt auch, sie haben keine Wertsemantik). Du musst entweder einen Zeiger oder eine Referenz übergeben. Im letzteren Fall musst du im Konstruktor eine Initialisierungsliste verwenden. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
oli83 Geschrieben 13. Juni 2005 Autor Teilen Geschrieben 13. Juni 2005 #include "lowercase.h" Tupel::Tupel(ifstream &file) : inFile (file) { } Tupel::~Tupel() { } FEHLER: error C2664: 'std::basic_ifstream<char,struct std::char_traits<char> >::basic_ifstream<char,struct std::char_traits<char> >(const char *,int)' : Konvertierung des Parameters 1 von 'class std::basic_ifstream<char,struct std::char_traits<char> >' in 'const char *' nicht moeglich Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
realisticer Geschrieben 13. Juni 2005 Teilen Geschrieben 13. Juni 2005 Zeig doch mal, wie du das aufrufst. mfg realisticer Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
oli83 Geschrieben 13. Juni 2005 Autor Teilen Geschrieben 13. Juni 2005 #include <fstream> using namespace std; class Tupel { public: Tupel(ifstream &file); // Konstruktor ~Tupel(); // Destruktor ifstream inFile; private: }; #include "lowercase.h" Tupel::Tupel(ifstream &file) : inFile (file) { } Tupel::~Tupel() { } #include <fstream> #include "lowercase.h" using namespace std; int main() { ifstream testFile; Tupel tupel1(testFile); return 0; } Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Klotzkopp Geschrieben 13. Juni 2005 Teilen Geschrieben 13. Juni 2005 class Tupel { public: Tupel(ifstream &file); // Konstruktor ~Tupel(); // Destruktor ifstream inFile; private: };[/CODE]Der Member muss auch eine Referenz werden. Sonst versucht der Compiler wieder, eine Kopie anzufertigen. Übrigens: Eine using namespace-Deklaration in einer Headerdatei ist nicht so gut. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.