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() { }
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.
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
realisticer Geschrieben 13. Juni 2005 Geschrieben 13. Juni 2005 Zeig doch mal, wie du das aufrufst. mfg realisticer
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; }
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.
Empfohlene Beiträge
Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren
Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können
Benutzerkonto erstellen
Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!
Neues Benutzerkonto erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden