oli83 Geschrieben 13. Juni 2005 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
Klotzkopp Geschrieben 13. Juni 2005 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
oli83 Geschrieben 13. Juni 2005 Autor 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
realisticer Geschrieben 13. Juni 2005 Geschrieben 13. Juni 2005 Zeig doch mal, wie du das aufrufst. mfg realisticer Zitieren
oli83 Geschrieben 13. Juni 2005 Autor 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
Klotzkopp Geschrieben 13. Juni 2005 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
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.