6Danke
ERLEDIGT
JA
JA
ANTWORTEN
13
13
ZUGRIFFE
474
474
EMPFEHLEN
-
01.05.12 09:16 #1
Mitglied Bronze
- Registriert seit
- May 2012
- Beiträge
- 32
Hallo Community,
Folgendes Problem - Sobald ich ein dynamisches Array in der Funktion "ein" mit werten Fülle spinnt der Destruktor (~zweidim) in der Funktion ... Wo ist der Fehler?
Code :1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231
#include "stdafx.h" #include <iostream> #include <cstring> using namespace std; class zweidim { private: double **d; size_t ax, ay; public: zweidim(int Zeilen=1, int Spalten=1) { ax = Zeilen; ay = Spalten; if(ax>0&&ay>0) { d = new double*[ax]; for(int co=0; co<ax; co++) { d[co] = new double[ay]; } for(int i=0;i<ax;i++) { for(int n=0;n<ay;n++) { d[i][n]=0.0; } } } else { cout<<"Falsche Eingabe "<<ax<<","<<ay<<"\n"; d = NULL; } } double* operator[] (int ax) { return & d[ax][ay]; } ~zweidim() { int i,n; for (i = 0; i < this->ax; i++) { delete [] d[i]; } delete [] d; } double summe(size_t ax0=0, size_t ax1=0,size_t ay0=0,size_t ay1=0) { double summe=0; double temp; //test ob ax/y0 > ax/y1 if(ax0>ax1) { temp=ax0; ax0=ax1; ax1=temp; } if(ay0>ay1) { temp=ay0; ay0=ay1; ay1=temp; } //test ende for(int i=0;i<ax1;i++) { for(int n=0;n<ay1;n++) { summe=summe+d[i][n]; } } return summe; } //Rückgabe von ax size_t get_ax() { return this->ax; } //Rückgabe von ay size_t get_ay() { return this->ay; } //Wert an Position x,y setzen void set(size_t ax=0, size_t ay=0, double wert=0.0) { if(d!=NULL && ax<this->ax && ay<this->ay) { cout<<"Es wurde "<<wert<<" an Position "<<ax<<","<<ay<<" eingefeugt\n"; d[ax][ay]=wert; } else { cout<<"Wert konnte nicht gesetzte werden, objekt nicht existent oder Position oberhalb des Arrays\n"; } } //Wert holen // Anzeigen double get(size_t ax=0, size_t ay=0) { if(ax>this->ax || ay>this->ay) { cout<<"Unzulässige Werte x y \n"; return 0; }else { return d[ax][ay]; } } //Anzeigen Aller Elemente void show(size_t ax0=0, size_t ax1=0, size_t ay0=0, size_t ay1=0) { //test auf 0>1 und auflösen bei fehler int temp; if(ax0>ax1) { temp=ax0; ax0=ax1; ax1=temp; } if(ay0>ay1) { temp=ay0; ay0=ay1; ay1=temp; }//test ende //Ausgabe Schleife for(int i=0;i<ax1;i++) { for(int n=0;n<ay1;n++) { cout<<d[i][n]<<"\t"; } cout<<"\n"; } }//Ende Show void ein(size_t ax0=0, size_t ax1=0, size_t ay0=0, size_t ay1=0) { double wert=0; //test auf 0>1 und auflösen bei fehler int temp; if(ax0>ax1) { temp=ax0; ax0=ax1; ax1=temp; } if(ay0>ay1) { temp=ay0; ay0=ay1; ay1=temp; }//test ende for(int i=0;i<ax1;i++) { for(int n=0;n<ay1;n++) { cout<<"Eingabe "<<i<<","<<n; cin>>wert; d[i][n]=wert; cout<<"\n"; } cout<<"\n"; } /*do { cout<<"d = "; cin>>d if(cin.eof()) break; if(cin.fail() || (cin.peek() != '\n')){ cin.clear(); cin.ignore(INT_MAX,'\n'); continue; } break; } while(true); */ } }; int main() { zweidim arr(3,3); cout<<"Ax="<<arr.get_ax()<<"\t Ay="<<arr.get_ay()<<"\n"; arr.set(1,2,20); cout<<"Summe = "<<arr.summe(1,3,1,3)<<"\n"; arr.ein(1,3,1,3); arr.show(1,3,1,3); arr.~zweidim(); cin.get(); return 0; }Geändert von Termos (01.05.12 um 10:54 Uhr)
-
01.05.12 11:08 #2
Hi
Ändere
zuCode cpp:1 2 3 4
double* operator[] (int ax) { return & d[ax][ax]; }
Code cpp:1 2 3 4
double*&operator[] (int ax) { return d[ax]; }
Noch was: ruf den Destruktor im main nicht selbst auf, das geht schon automatisch.
GrußNetiquette (vA §15) und Nutzungsregeln (vA §4.8) einhalten! Programmcode in Codetags/Codeboxen.
Sehr gute Beiträge bitte Bewerten (Stern darunter oder "Danke").
"Funktioniert nicht" ist zu ungenau! Code, Fehlermeldungen, Verhalten des Programms, ...?
-
01.05.12 11:25 #3
Mitglied Gold
- Registriert seit
- Feb 2011
- Beiträge
- 205
Was genau passiert denn beim Destruktor?
Vorweg nur 2 Sachen: Beim operator[] übergibst du ein ax, ein ay aber nicht und da es eine Membervariable gibt, die auch so heißt, nimmt die Funktion das ay der class, ist das so beabsichtigt? Ich glaube eher nicht oder?
Und in der main() rufst du den Destruktor explicit auf, das darfst du nicht machen, er wird vom Compiler am Ende von main() noch einmal aufgerufen und 2mal den Destruktor für dasselbe Objekt verwenden macht Probleme!
Lg
-
01.05.12 11:28 #4
Mitglied Bronze
- Registriert seit
- May 2012
- Beiträge
- 32
Super vielen dank, hat funktioniert
jetzt hab ich das Problem das ich beim Füllen der Elemente einen Fehler im Speicher erzeuge ...
Ist einfach die schleife falsch und ich versuche auf unreservierten speicher zuzugreifen?
Code :1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
void ein(size_t ax0=0, size_t ax1=0, size_t ay0=0, size_t ay1=0) { int wert=0; //test auf 0>1 und auflösen bei fehler int temp; if(ax0>ax1) { temp=ax0; ax0=ax1; ax1=temp; } if(ay0>ay1) { temp=ay0; ay0=ay1; ay1=temp; }//test ende for(int i = ax0;i <=ax1;i++) { for(int n = ay0;n <=ay1;n++) { cout<<"Eingabe ["<<i<<"],["<<n<<"] = "; cin>>wert; d[i][n]=wert; cout<<"\n"; } cout<<"\n"; } /*do { cout<<"d = "; cin>>d if(cin.eof()) break; if(cin.fail() || (cin.peek() != '\n')){ cin.clear(); cin.ignore(INT_MAX,'\n'); continue; } break; } while(true); */ }
Code :1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
int main() { zweidim arr(3,3); cout<<"Ax="<<arr.get_ax()<<"\t Ay="<<arr.get_ay()<<"\n"; arr.set(1,2,20); cout<<"Summe = "<<arr.summe(1,3,1,3)<<"\n"; arr.ein(1,3,1,3); arr.show(1,3,1,3); system("PAUSE"); return 0; }
-
01.05.12 11:38 #5
Mitglied Gold
- Registriert seit
- Feb 2011
- Beiträge
- 205
Du erstellst das Objekt mit 3 Zeilen und 3 Spalten, das bedeutet für den Index bei der Arrayschreibweise ist eine Zahl von 0 bis 2 möglich. Du rufst ein() aber mit 1 und 3 auf, und in der Füllschleife in ein() steht i <= ax1, das bedeutet er arbeitet mit Index 3 auch noch, das ist der Fehler.
Am besten machst du bei dieser Funktion gleich am Anfang eine Überprüfung, ob die Grenzen beim Array nicht überschritten werden.
Lg
-
01.05.12 11:55 #6
Mitglied Bronze
- Registriert seit
- May 2012
- Beiträge
- 32
So n dummer Fehler ;( Vielen Dank - Wird zeit für Frühstück
-
01.05.12 13:07 #7
Mitglied Bronze
- Registriert seit
- May 2012
- Beiträge
- 32
hab es jetzt bis auf die ganzen Fehler abfragen soweit fertig, getestet mit
3x3 Matrix ... Problem macht immer noch die Ausgabe.
/*
Zeilen Anzahl: 3
Spalten Anzahl: 3
Element [3][3] = 0 Eigentlich sollte hier 100 stehen auf Index [2][2] im Speicher ... in der Tabelle steht es richtig da ... Spreche ich mit meinem Aufruf ein falsches Element an?
[/COLOR]
0 0 0
0 0 0
0 0 100
Eingabe [0],[0] = 1
Eingabe [0],[1] = 2
Eingabe [0],[2] = 3
Eingabe [1],[0] = 4
Eingabe [1],[1] = 5
Eingabe [1],[2] = 6
Eingabe [2],[0] = 7
Eingabe [2],[1] = 8
Eingabe [2],[2] = 9
1 2 3
4 5 6
7 8 9
gesamtsumme = 45
Drücken Sie eine beliebige Taste . . .
*/
Code :1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249
#include "stdafx.h" #include <iostream> #include <cstring> using namespace std; class zweidim { private: double **d; size_t ax, ay; public: zweidim(int Zeilen=1, int Spalten=1) { ax = Zeilen; ay = Spalten; if(ax>0&&ay>0) { d = new double*[ax]; for(size_t co=0; co<ax; co++) { d[co] = new double[ay]; } for(size_t i=0;i<ax;i++) { for(size_t n=0;n<ay;n++) { d[i][n]=0.0; } } } else { cout<<"Falsche Eingabe "<<ax<<","<<ay<<"\n"; d = NULL; } } double *& operator[] (int ax) { return d[ax]; } /* ~zweidim() { int i; for (i = 0; i < ax; i++) delete [] d[i]; delete [] d; }*/ ~zweidim() { if(d != NULL) { for(size_t i=0; i < ax; i++) for(size_t j=0; j < ay; j++) if(d[i] != NULL) { delete d[i]; d[i] = NULL; } delete [] d; d = NULL; } } double summe(size_t ax0=0, size_t ax1=0,size_t ay0=0,size_t ay1=0) { double summe=0; size_t temp; //test ob ax/y0 > ax/y1 if(ax0>ax1) { temp=ax0; ax0=ax1; ax1=temp; } if(ay0>ay1) { temp=ay0; ay0=ay1; ay1=temp; } //test ende for(size_t i=0;i<ax1;i++) { for(size_t n=0;n<ay1;n++) { summe=summe+d[i][n]; } } return summe; } //Rückgabe von ax size_t get_ax() { return this->ax; } //Rückgabe von ay size_t get_ay() { return this->ay; } //Wert an Position x,y setzen void set(size_t ax=0, size_t ay=0, double wert=0.0) { if(d!=NULL && ax<this->ax && ay<this->ay) { d[ax][ay]=wert; } else { cout<<"Wert konnte nicht gesetzte werden, objekt nicht existent oder Position oberhalb des Arrays\n"; } } //Wert holen // Anzeigen double get(size_t ax=0, size_t ay=0) { if(ax>this->ax || ay>this->ay) { cout<<"Unzulässige Werte x y \n"; return 0; }else { return d[ax][ay]; } } //Anzeigen Aller Elemente void show(size_t ax0=0, size_t ax1=0, size_t ay0=0, size_t ay1=0) { //test auf 0>1 und auflösen bei fehler int temp; if(ax0>ax1) { temp=ax0; ax0=ax1; ax1=temp; } if(ay0>ay1) { temp=ay0; ay0=ay1; ay1=temp; }//test ende //Ausgabe Schleife for(size_t i=0;i<ax1;i++) { for(size_t n=0;n<ay1;n++) { cout<<d[i][n]<<"\t"; } cout<<"\n"; } }//Ende Show void ein(size_t ax0=0, size_t ax1=0, size_t ay0=0, size_t ay1=0) { int wert=0; //test auf 0>1 und auflösen bei fehler int temp; if(ax0>ax1) { temp=ax0; ax0=ax1; ax1=temp; } if(ay0>ay1) { temp=ay0; ay0=ay1; ay1=temp; }//test ende if(d!=NULL && ax0>0 && ay0>0) { for(size_t i = ax0-1;i <=ax1-1;i++) { for(size_t n = ay0-1;n <=ay1-1;n++) { cout<<"Eingabe ["<<i<<"],["<<n<<"] = "; cin>>wert; d[i][n]=wert; cout<<"\n"; } cout<<"\n"; } }else {cout<<"Fehler in Aufruf, ax ay dürfen nciht 0 sein\n";} /*do { cout<<"d = "; cin>>d if(cin.eof()) break; if(cin.fail() || (cin.peek() != '\n')){ cin.clear(); cin.ignore(INT_MAX,'\n'); continue; } break; } while(true); */ } }; int main() { int ax,ay; cout<<"Zeilen Anzahl: "; cin>>ax; cout<<"Spalten Anzahl: "; cin>>ay; zweidim d(ax,ay); d.set(ax-1,ay-1,100); cout<<"Element ["<<ax<<"]["<<ay<<"] = "<<*d[ax-1,ay-1]<<"\n"; d.show(1,ax,1,ay); d.ein(1,ax,1,ay); d.show(1,ax,1,ay); cout<<"gesamtsumme = "<<d.summe(1,ax,1,ay)<<"\n"; system("PAUSE"); return 0; }
-
01.05.12 13:19 #8
Mitglied Gold
- Registriert seit
- Feb 2011
- Beiträge
- 205
Dein operator[] ist das Problem, er erwartet ja nur ein Argument, du musst den so schreiben, dass er 2 Argumente bekommt und genau das Element der Matrix zurückgibt, im Moment macht er ganz was anderes.
Lg
-
01.05.12 13:38 #9
Mitglied Bronze
- Registriert seit
- May 2012
- Beiträge
- 32
hast einen tipp nach was ich genau googeln kann?
habe jetzt alles zur Operator Überladung c++ gelesen, nirgends der Fall das ich 2 Argumente übergeben kann ... muss ich mit zeigern arbeiten um den 2ten wert zu bekommen?
Oder sollte diese Form weiterhelfen?
Code :1 2
inline virtual const type& operator[](register const unsigned long index) const { return _pointer[index]; } inline virtual type& operator[](register const unsigned long index) { return _pointer[index]; }
-
01.05.12 14:55 #10
Mitglied Gold
- Registriert seit
- Feb 2011
- Beiträge
- 205
Du könntest entweder den operator () überladen oder versuch es mal mit einem pair. Google mal pair.
Lg
-
01.05.12 14:56 #11
Mitglied Bronze
- Registriert seit
- May 2012
- Beiträge
- 32
Hab vielen dank
-
01.05.12 14:58 #12
Man kann [] nicht zwei Parameter geben (bzw. wenn man das Klassenobjekt
mitzählt sinds zwei, aber sonst...)
Oben hast du schon mal geschrieben, das [] funktioniert hat.
Warum nicht so lassen?
Falschzugriffe kommen vom übergebenen Index, da kann [] nichts dafür.Netiquette (vA §15) und Nutzungsregeln (vA §4.8) einhalten! Programmcode in Codetags/Codeboxen.
Sehr gute Beiträge bitte Bewerten (Stern darunter oder "Danke").
"Funktioniert nicht" ist zu ungenau! Code, Fehlermeldungen, Verhalten des Programms, ...?
-
01.05.12 15:00 #13
Mitglied Bronze
- Registriert seit
- May 2012
- Beiträge
- 32
Da hatten alle Elemente den Wert 1 ... Ergo falsch getestet ... jetzt bekomme ich bei a[2][2] nur einen speicherwert bzw speichermüll raus ... (Dereferenziert)
-
01.05.12 15:17 #14
Mitglied Bronze
- Registriert seit
- May 2012
- Beiträge
- 32
Okay Fehler umgangen, ich benutze einfach die get() Funktion der Klasse.
Vielen Dank für eure Hilfe******!
Ähnliche Themen
-
Problem mit Mehrdimensionalem Array
Von xtramen01 im Forum PHPAntworten: 4Letzter Beitrag: 23.07.10, 15:31 -
aus Mehrdimensionalem Array ein Eindimensionales Array erstellen
Von FiselM im Forum Java GrundlagenAntworten: 8Letzter Beitrag: 22.06.10, 17:20 -
Denklücke / Problem mit mehrdimensionalem Array
Von Mik3e im Forum PHPAntworten: 1Letzter Beitrag: 20.02.06, 11:44 -
Problem mit mehrdimensionalem Array
Von timäää im Forum Flash PlattformAntworten: 8Letzter Beitrag: 15.08.05, 13:57 -
[C++] Problem mit mehrdimensionalem Array
Von Yupa im Forum C/C++Antworten: 7Letzter Beitrag: 25.04.04, 19:07




Zitieren

Login
