LLpresident Geschrieben 30. Oktober 2003 Teilen Geschrieben 30. Oktober 2003 habe ein problem. wenn ich mein projekt compieliere bekomme ich folgende fehlermeldung: Im Projekt proLogdateienauswerter.exe ist eine Exception der Klasse EListError aufgetretten. Meldung: 'Der Index der Liste überschreitet das Maximum(7) '. Prozeß wurde angehalten. Mit Einzelne Anweisung oder Start fortsetzten. mein quelltext sieht wie folgt aus: //-------------------------Application filtern------------------------------- //--------------------------------------------------------------------------- void __fastcall TfrmMain::App_Filter() { memset(Zeile_ZuFiltern, 0, 6); memset(Zeile_Filter, 0, 6); memset(Zeile, 0, 3); ifstream ZuFiltern("c:\\Programme\\Borland\\CBuilder5\\Projects\\LogAuswerter_Abschluss\\Programm\\application_temp.txt", ios::in); Tab = 0; Zaehler = 0; Vorhanden = 0; Gespeichert = 0; Bestanden_Zaehler = 0; while(!ZuFiltern.eof()) { Zaehler++; ZuFiltern.get(Zeichen_ZuFiltern); Zeile_ZuFiltern[0] = Zeile_ZuFiltern[1]; Zeile_ZuFiltern[1] = Zeile_ZuFiltern[2]; Zeile_ZuFiltern[2] = Zeile_ZuFiltern[3]; Zeile_ZuFiltern[3] = Zeile_ZuFiltern[4]; Zeile_ZuFiltern[4] = Zeile_ZuFiltern[5]; Zeile_ZuFiltern[5] = Zeichen_ZuFiltern; if(Zeichen_ZuFiltern == Tabulator) { Tab++; } if(Zeichen_ZuFiltern == EndOfLine) { Tab = 0; Zaehler = 0; } if(Tab == 5) { Pos = 0; Vorhanden = 0; ifstream Filter("c:\\Programme\\Borland\\CBuilder5\\Projects\\LogAuswerter_Abschluss\\Programm\\application.txt", ios::in); Tab = 0; while(!Filter.eof()) { Filter.get(Zeichen_Filter); Zeile_Filter[0] = Zeile_Filter[1]; Zeile_Filter[1] = Zeile_Filter[2]; Zeile_Filter[2] = Zeile_Filter[3]; Zeile_Filter[3] = Zeile_Filter[4]; Zeile_Filter[4] = Zeile_Filter[5]; Zeile_Filter[5] = Zeichen_Filter; if(Zeichen_Filter == Tabulator) { Tab++; } if(Zeichen_Filter == EndOfLine) { Tab = 0; Pos++; } //**************Überprüfen ob Zeile_Zu Filtern gleich Teile_Filter*********** if(Tab == 5) { Bestanden_Zaehler = 0; for(Vergleich = 0; Vergleich < 6; Vergleich++) { if(Zeile_Filter[Vergleich] == Zeile_ZuFiltern[Vergleich]) { Bestanden = 1; Bestanden_Zaehler++; if(Bestanden_Zaehler == 6) { Bestanden_Erfolgreich = 1; clbApp_Akt_Fehler->Checked[Pos] = true; ifstream::pos_type pos= Filter.tellg(); Zaehler = Zaehler - 1; pos = pos - Zaehler; Filter.seekg(pos); ofstream String("E_Mail_Text.txt", ios::app); while(Zeichen_Filter != EndOfLine) { Filter.get(Zeichen_Filter); String << Zeichen_Filter; } } else { Bestanden = 0; } } if(Zeile_Filter[Vergleich] != Zeile_ZuFiltern[Vergleich]) { Bestanden = 0; } } } //*************************************************************************** if(Bestanden != 1 && Tab == 5 && Vorhanden != 1) { Vorhanden = 0; Gespeichert = 0; Tab = 0; } if(Bestanden == 1 && Bestanden_Erfolgreich == 1) { Vorhanden = 1; Gespeichert = 1; Tab = 0; } } if(Gespeichert == 0) { ifstream::pos_type pos = ZuFiltern.tellg(); pos = pos - Zaehler; ZuFiltern.seekg(pos); ofstream NichtGefiltert("c:\\Programme\\Borland\\CBuilder5\\Projects\\LogAuswerter_Abschluss\\Programm\\application.txt", ios::app); while(Zeichen_ZuFiltern != EndOfLine) { ZuFiltern.get(Zeichen_ZuFiltern); NichtGefiltert << Zeichen_ZuFiltern; Gespeichert = 1; } } Filter.close(); } Bestanden = 0; Bestanden_Erfolgreich = 0; } ZuFiltern.close(); } [/PHP] wo liegt der fehler? meistens überspringt er den letzten teil. habs auch schon mit try-chatch versucht. hat aber auch nicht geholfen. diese funktion kommt in leicht veränderter form( andere dateinen werden includet, andere checklistboxen werden angesprochen) noch 2 mal vor. thx schon mal im vorraus. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
LLpresident Geschrieben 31. Oktober 2003 Autor Teilen Geschrieben 31. Oktober 2003 ok.hab den fehler grade gefunden. hier liegt der fehler: for(Vergleich = 0; Vergleich < 6; Vergleich++) habe das array mit 6 definiert. also 0,1,2,3,4,5 aber in der oben gezeigten for-schleife 0,1,2,3,4,5,6 abgefragt. dadurch hat er mir beim letzten immer gesagt das der zu viel ist. hoffe das es denjenigen die auch mal son problem haben hilft. gruss zen. 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.