Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)"
-
@Quiche-Lorraine sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
"Komm beruhige dich. Aber der Code funktioniert seit Jahren problemlos bzw. fehlerfrei, also warum sollte dieser schlecht sein? Und außerdem, der letzte Software-Entwickler wollte dies auch schon ändern und hat dabei einen großen Bock geschossen."
Das Problem bei solcher Software ist oftmals, dass der reine Softwareentwickler nicht weiß was da konkret gemacht wird. Das vergrößert die Wahrscheinlichkeit, dass Fehler bei Optimierungen oder Refactoring in den Code kommen, die jemand der von der Fachseite ist, sofort erkennen würde.
-
Nochmal vielen Dank an alle.
Und ja, der Code ist sau alt. Er wurde (zumindest dieser Teil) schon von meinem Vorgänger aus einem vorherigen Projekt übernommen.
Und ich habe mich immer davor gegraut, diesen Teil jemals anfassen zu müssen.
Und nun wars eben soweit.
Ich habe hier ein paar grausige Code-Schnipsel reingestellte, mit denen ich rumexperimentiert habe, um zu sehen, was wann schief geht.
Und mein Programmierwissen bedarf sicherlich auch einer Auffrischung.
Aber bitte beurteilt es nicht nach diesen Codeschnipseln.
Und ja, ich bin auch der einzige, der an dem Ding arbeitet und bekomme die Wünsche zur Weiterentwicklung zugetragen.Alles was ich gemacht habe, ist:
- Ich habe zwei zentrale Objekte, so wie sie zuvor waren, hergenommen und sie in jeweils in eine "std::map" reingesetzt.
- Dann habe ich einfach versucht, sie nach Gebrauch ordentlich zu bereinigen.
- Auch habe ich das so versucht, wie hier vorgeschlagen, alles an möglichst wenig Stellen und am Ort ihrer Entstehung zu behandeln.
Und @Quiche-Lorraine So wie Du sagst ist es eben mal die Realität.
Man bekommt ein paar hunderttausend Codezeilen nicht mal so eben "reengineered".
Zumal ich noch nicht mal das Kommunikations-Protokoll und die darin immer noch versteckten Fehler alle verstanden habe.
Und diesen knapp 30 Jahre alten Ringspeicher (natürlich undokumentiert) schon gar nicht.
Aber über den läuft nun mal die Kommunikation, und er wird auch irgendwie noch ans HMI weitergereicht.Beim Versuch die Objekte zu bereinigen sind an vielen Stellen solche Konstrukte zusammengekommen.
Und so wird aus einem anfänglich "einzigen und vermutlich kleinem" Problem eben ein Desaster.
-
@Th69 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
@elmut19. Warum kannst du
cppcheck
nicht installieren?Tja, das wüsste ich auch gerne!
Ich gehe so vor, wie es mir vom System gesagt wird.
Download von der Website und auf "Ausführen" klicken.
Dann kommt halt diese Meldung. Mein VS2019 wird jedenfalls noch erkannt.
Und diesem wird die Zusammenarbeit verweigert
-
@elmut19 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
@Th69 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
@elmut19. Warum kannst du
cppcheck
nicht installieren?Tja, das wüsste ich auch gerne!
Ich gehe so vor, wie es mir vom System gesagt wird.
Download von der Website und auf "Ausführen" klicken.
Dann kommt halt diese Meldung. Mein VS2019 wird jedenfalls noch erkannt.
Und diesem wird die Zusammenarbeit verweigertCppCheck ist eigentlich eine eigenständige Anwendung. Auf die Integration in VS bist du nicht unbedingt angwiesen.
-
@It0101 Aha. Vielen Dank!
Ich habe ein gleichnamiges Paket als ".vsix"-Datei unter den Erweiterungen von VS2019 gefunden. Und das lies sich nicht installieren.Das eigenständige cppcheck habe ich mal bei mir zuhause installiert.
Und da muss ich mich wohl einarbeiten.
Aber erstmal habe und brauche ich diese Woche mal Urlaub.
-
CPPCheck ist kein Hexenwerk. Neue Projektdatei erstellen und los gehts. Dann bekommst du die einzelnen Dateien mit auffälligen Codestellen aufgelistet. Etwas filtern kannst du auch noch.
CPPCheck ist kein Gesetzbuch, aber es macht Sinn sich die Meldungen zumindest mal anzusehen und dann individuell zu entscheiden ob es Sinn macht, den Code anzupassen.
-
@It0101 Also CppCheck findet auch nix Relevantes.
Leider ist es nichtmal in der Lage, alle Dateien im Projekt einzulesen.@DocShoe Smartpointer habe ich nur mal kurz, also ganz kurz angelesen.
Das scheint eher den Sinn zu haben, dass man auf ein "delete()" zum Abschluss verzichten kann.
Denke nicht, dass das mein Problem löst.Habe nun sogar noch einen Trick versucht, um die "map" zu verarschen,
indem ich sie, statt des Pointers auf mein Objekt, mit einem "void*" pointer versehe.
NEIN! Die "map" lies sich nicht verarschen!
-
@elmut19 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
@It0101 Also CppCheck findet auch nix Relevantes.
Leider ist es nichtmal in der Lage, alle Dateien im Projekt einzulesen.@DocShoe Smartpointer habe ich nur mal kurz, also ganz kurz angelesen.
Das scheint eher den Sinn zu haben, dass man auf ein "delete()" zum Abschluss verzichten kann.
Denke nicht, dass das mein Problem löst.Warum denkst du das? Memory management ist ja augenscheinlich die Ursache für deine Probleme. Warum also das Thema nicht radikal vereinfachen?
Habe nun sogar noch einen Trick versucht, um die "map" zu verarschen,
Ganz schlechte Idee. Die Map ist eh nicht das Problem.
indem ich sie, statt des Pointers auf mein Objekt, mit einem "void*" pointer versehe.
NEIN! Die "map" lies sich nicht verarschen!Siehste.
-
@Tyrdal
Klar Memorymanagement!
Aber das verstehe ich leider nicht an der Stelle, gerade das mit dem "Orphan".
Ich hatte ja schon alle erdenklichen Zugriffsfehler an dieser Stelle.
Aber alle, bis auf diesen, sind leicht erkennbar und lösbar.
Und hier ist die "map" sogar leer und alle Objekte, die darin waren, wurden ordentlich bereinigt!Und noch eine kurze Korrektur zu einer vorherigen Aussage:
Wenn ich eine Release-Version baue, statt es im Debugger laufen zu lassen,
wird die Anwendung ohne eine Fehlermeldung beendet!
-
@elmut19 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
@Tyrdal
Klar Memorymanagement!
Aber das verstehe ich leider nicht an der Stelle, gerade das mit dem "Orphan".
Ich hatte ja schon alle erdenklichen Zugriffsfehler an dieser Stelle.
Aber alle, bis auf diesen, sind leicht erkennbar und lösbar.
Und hier ist die "map" sogar leer und alle Objekte, die darin waren, wurden ordentlich bereinigt!Da hat wohl vorher was den den Speichern durcheinandergebracht.
Und noch eine kurze Korrektur zu einer vorherigen Aussage:
Wenn ich eine Release-Version baue, statt es im Debugger laufen zu lassen,
wird die Anwendung ohne eine Fehlermeldung beendet!Im Debugmode können zusätzliche Sachen laufen (Bounds check etc), die im Release so nicht passieren. Deshalb ist der Fehler aber nicht im Release verschwunden.
-
@Tyrdal sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
Deshalb ist der Fehler aber nicht im Release verschwunden.
Deshalb versuche ich ja das Zeug verzweifelt zu verstehen und auch zu korrigieren.
-
@elmut19 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
@Tyrdal sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
Deshalb ist der Fehler aber nicht im Release verschwunden.
Deshalb versuche ich ja das Zeug verzweifelt zu verstehen und auch zu korrigieren.
Sicher? Die Hinweise nimmst du nicht besonders ernst.
-
@Tyrdal natürlich nehme ich sie ernst.
Aber alles Ernstnehmen hilft nix, wenn ich das Problem nicht finde.Mein Vorgänger hat nun mal eine äusserst verschachtelte Struktur aufgebaut,
die ich nicht ohne Neubau der ganzen Anwendung umformen kann,
und die ich leider auch nur oberflächlich verstehe.Mir scheint langsam, dass ich um ein persönliches Coaching nicht rumkomme.
-
@elmut19 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
Mein Vorgänger hat nun mal eine äusserst verschachtelte Struktur aufgebaut,
die ich nicht ohne Neubau der ganzen Anwendung umformen kann,
und die ich leider auch nur oberflächlich verstehe.Das ist natürlich ein Problem, aber was sollen wir da sonst noch empfehlen? Es gibt einen Fehler in einem hochkomplexen System, sprich das System ist fehlerhaft gebaut. Was hast du für Optionen, diesen Fehler zu beheben, außer
a) Das hochkomplexe System komplett zu verstehen und damit auch den Fehler (und das Schlimmste: Verstehen garantiert nicht einmal, dass man den Fehler dann auch beheben kann)
b) Ein neues System ohne Fehler zu bauen?
Ist doch klar, dass wir da Option b empfehlen werden, zumal es ziemlich offensichtlich ist, dass die Komplexität nicht nötig ist. Option a kannst nur du alleine machen, außer du stellst jemanden von uns ein. Und eine andere Option gibt es halt nicht wirklich. Es gibt keinen magischen "mach den Fehler weg" Knopf in der Programmierung.
-
@SeppJ so siehts wohl aus ....
Hatte gehofft, es gäbe für das "Orphan" eine überschaubare Eingrenzungsmöglichkeit der Fehlerart.
Vielen Dank nochmals an alle.
-
@elmut19 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
Leider ist es nichtmal in der Lage, alle Dateien im Projekt einzulesen.
Da würde ich dir raten, der Sache mal nachzugehen. Er liest eigentlich alles ein.
Andererseits klingt das Projekt, als wären auch, in Macros versteckte, Klassen zu erwarten, oder irgendwelche Schutzschilde um Qualitätskontrolle zu verhindern.#ifdef CPPCHECK #define HIDE_SOURCECODE #endif
-
@elmut19 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
Mir scheint langsam, dass ich um ein persönliches Coaching nicht rumkomme.
Du kommst um ein Redesign dieser Komponenten nicht herum. Aber ich verstehe dich gut. Man bekommt uralten Quellcode vorgeworfen, aber vom Chef nicht die Zeit dafür, den ganzen Misthaufen mal neu zu machen. Man kennt es...
-
@It0101 Mein Vorgänger war sehr verliebt in Makros.
-
@elmut19 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
@It0101 Mein Vorgänger war sehr verliebt in Makros.
Noch ein Punkt mehr für das Redesign.
Du kannst jetzt hier noch 10 Seiten schreiben, aber ich lese da nur:
Redesign Redesign Redesign Redesign Redesign Redesign Redesign Redesign Redesign Redesign
-
@It0101 sagte in Zugriffsfehler auf "std::map" in " _Orphan_ptr(const _Nodeptr _Ptr)":
Redesign Redesign Redesign Redesign Redesign Redesign Redesign Redesign Redesign Redesign