![]() |
Seltsame Fehler in Delphi
Hallo,
das hier wird jetzt länger ...geht aber nicht anders. Ich habe nun schon seit über zwei Wochen Tag für Tag mit "seltsamen" Fehlern in meinem Delphi-Programm zu kämpfen. Bei dem Programm handelt es sich um eine Applikation im Bereich Computer Vision, die zum Personen Tracking mit Hilfe von zwei Kameras gedacht ist. Dabei kommen zwei externe Bibliotheken zum Einsatz: DSPack 2.3.4., um mittels Direct Show auf die beiden Kameras zuzugreifen und OpenCV Beta 4, eine OpenSource-Bibliothek - geschrieben in C - die mir diverse Algorithmen zur Bildverarbeitung bereitstellt. Mit "seltsamen" Fehlern meine ich z.B. folgendes:
Im allgemeinen habe ich festgestellt: sobald ich mein Programm etwas schlanker mache, verschwinden die "seltsamen" Fehler und das Programm verhält sich wieder ordnungsgemäß. In 2) reichte schon das Entfernen eines GUI-Elements dazu aus. Manchmal reicht es auch, irgendein Form aus dem Projekt zu entfernen (welches nie aufgerufen wird). Dieses Verhalten macht die Sache für mich sehr kompliziert. Ich bin nicht in der Lage, den Fehler zu extrahieren, d.h. das Programm soweit herunerzu-"schlanken" dass es in ein Forum passt. Desshalb kann ich hier nur allgemeine Hinweise zum Programm geben und hoffen, dass mir jemand zumindest eine grobe Richtung für die Fehlersuch weisen kann. Hier also Infos, die evtl. wichtig sein könnten:
Bin mal gespannt, was jetzt für Hinweise kommen. Bin total verzweifelt (und das ist noch untertrieben) und habe nach so langer Zeit wirklich kaum noch Lust auf Fehlersuche. Gruß, oXmoX |
Re: Seltsame Fehler in Delphi
Hi oXmoX,
ich kenne das Gefühl. Vielleicht überschreiben dir DSPACK-Routinen Teile deines Programms, weil du irgendwo Zeigervariablen übergibst, wo du Zeiger auf Zeigervariablen hättest übergeben müssen - eine beliebte Fehlerquelle beim Verbinden von Delphi-Programmen mit C-DLLs, vor der auch Profis nicht gefeit sind. Grüße vom marabu |
Re: Seltsame Fehler in Delphi
Zitat:
Danke für den Tip. |
Re: Seltsame Fehler in Delphi
Moin, moin,
also zunächstmal dürfen keine DCU´s gleichen Namens im Suchpfad sein Zwischendurch am besten mal alle löschen. Sonst hört sich das doch nach einem Pointerproblem an. Würde mal folgendes Probieren. Kopiere Dir Dein Projekt und füge der Kopie zum größer machen mal eine Riensgrafik (Bild) im Programm ein. Und jetzt nimm kritisches Formular für Formular aus dem Projekt. Pointer und Create/Destroy-Probleme zu finden ist keine einfache Geschichte... Grüße /// Martin |
Re: Seltsame Fehler in Delphi
Moin Oxmox,
ich würde es mal mit MemProof bzw. MemChk versuchen. Vielleicht lässt sich damit die Ursache finden, bzw. einkreisen. |
Re: Seltsame Fehler in Delphi
Danke für den Tip mschaefer!
Werd mal ein wenig herumbasteln. Grad eben habe ich das Start-Form durch ein neues ersetzt. Daraufhin war der Fehler natürlich weg. Als ich wieder auf das ursprüngliche Startformular geschaltet habe tauchte der Fehler auch nicht mehr auf. Auf einmal lief alles einwandfrei ...bis ich dann das Formular um einen sinnlosen Button erweitert habe. Da war der Fehler dann wieder da. Ein weitere Workaround bringt mich hier nicht weiter ...diesem Fehler habe ich jedenfalls den Krieg erklärt :twisted: . Stellt euch mal vor, ihr würdet nun schon 2 Wochen lang erfolglos versuchen soeinem Fehler auf die Spur zu kommen. Ich schätze ich hab's nicht mehr weit bis zum Irrenhaus. ...naja, keine Sorge: noch gehts mir gut ;) Gruß, oXmoX |
Re: Seltsame Fehler in Delphi
Zitat:
Gruß, oXmoX |
Re: Seltsame Fehler in Delphi
Bei mir half es schon einmal, die Reihenfolge der unter uses ... eingebundenen Units zu ändern.
mfg |
Re: Seltsame Fehler in Delphi
Dann hätte ich gleich mal noch eine Frage zum Thema Speicherbereinigung. Wie mache ich das denn bei Interfaces? Z.B. erstelle ich irgendwo ein IXMLDocument mit
Code:
Dann habe ich über das Interface eine Referenz auf ein neu erstelltes Objekt. Muss ich mich da etwa auch um die Wieder-Freigabe kümmern? Die Methode _Realease bringt irgendwie nicht den gewünschten Effekt (sag zumindest MemProof).
MyXmlDoc := NewXMLDocument;
|
Re: Seltsame Fehler in Delphi
Ich würde erwarten, dass der folgende Code keine memory leaks hinterlässt:
Delphi-Quellcode:
Grüße vom marabu
uses
MSXML2; var doc: IXMLDOMDocument; begin // OleInitialize(nil); doc := CoDomDocument.Create; doc := nil; end; |
Re: Seltsame Fehler in Delphi
@marabu: Danke ...meine Leaks sind jetzt weg (Lag noch woanders dran bei mir).
Nächte Frage: gibt es ein Tool, das mir unbenötigte Units aus den uses-Abschnitten entfernt. Oder muß ich mir die ganze Arbeit etwa selbst machen? |
Re: Seltsame Fehler in Delphi
Im Interface-Abschnitt ist das kein großes Problem. Lösche doch einfach die uses Klausel (oder kommentiere sie aus) und speichere die Datei neu. Nun baut Delphi alle benötigten Units in die uses Klausel ein. So kannst Du das bei jeder Datei machen. Units, die nicht zu einer Komponente gehören sollte man eh, soweit möglich, in den implementation Abschnitt verlagern, da man auf den Inhalt dieser Units so gut wie nie zugreifen muß (im Interface-Abschnitt). Übrigens: Bei diesen Units fragt Dich Delphi zur Not, ob es sie in die Uses Klausel aufnehmen soll, falls Du eine vergessen hast.
|
Re: Seltsame Fehler in Delphi
Zitat:
|
Re: Seltsame Fehler in Delphi
Zitat:
Mir ist übrigens beim Analysieren meiner uses-Klauseln aufgefallen, dass "TBitmap" zweimal deklariert wird: einmal in "Windows" und einmal in "TGraphics". ...Seltsam. |
Re: Seltsame Fehler in Delphi
Windows.TBitmap - muss ein Irrtum sein...
|
Re: Seltsame Fehler in Delphi
Zitat:
|
Re: Seltsame Fehler in Delphi
Zitat:
|
Re: Seltsame Fehler in Delphi
Während mein Server im Keller noch gehustet hat kam schon die Erklärung von Bernhard. Und warum ich mit Strg-F in Windows.pas nix gefunden habe - das behalte ich lieber für mich...
marabu |
Re: Seltsame Fehler in Delphi
Das bedeutet also für mich, dass die Reihenfolge im uses-Teil eine Rolle Spielt. Ich muss ständig darauf achten, dass "Graphics" vor "Windows" steht, da ich nicht mit dem Record, sondern mit der Klasse arbeiten will.
Wie kann ich denn explizit ein TBitmap einer bestimmten Unit ansprechen? |
Re: Seltsame Fehler in Delphi
Über qualified names: windows.tbitmap
|
Re: Seltsame Fehler in Delphi
Ok ...geht mit Windows.TBitmap oder Graphics.TBitmap ...habs verstanden
Edit: ...und war zu langsam ;) |
Re: Seltsame Fehler in Delphi
Zitat:
mschaefer hat es eigentlich schon angesprochen. Zitat:
Ich empfehle Dir deshalb für Dein Projekt folgende dinge zu beachten.
Damit sollten Deine Probleme erledigt sein. |
Re: Seltsame Fehler in Delphi
Zitat:
Z.Zt. sind die Fehler - als Folge eines kleinen Refactorings - sowieso nicht mehr vorhanden. Meine Klassen sind jetzt insgesamt etwas kleiner (vorher hatten einige Klassen locker über 1000 Zeilen), mein Heap ist sauber (dank MemProof) und die uses-Abschnitte enthalten keine unnötigen Referenzen (dank Icarus). Außerdem habe ich Abhängigkeiten, die ich nicht unbeding benötige entfernt (z.B. ein DirectX-Filter zum Skalieren des Bildes). Wie gesagt: wenn ich den Umfang reduziere verschwinden die Fehler. Aber ich befürchte trotzdem, dass sie zurückkommen. Daher mache ich ja grad diese große Aufräumaktion. Deine Vorschläge hab ich mir mal zu Herzen genommen. Meine dcu's landen jetzt in einem Sonderverzeichnis, dass regelmäßig gelöscht wird. Mal sehen ob's was bringt. Wenn ich Glück habe taucht der Fehler ja auch nicht wieder auf. Gruß, oXmoX |
Re: Seltsame Fehler in Delphi
...und noch eine Frage:
In einem Der C-Header-Files, die ich für Delphi umgesetzt habe steht die Zeile
Code:
IPL_DEPTH_SIGN wird in den nachfolgenden Zeilen dann als "int" verwendet.
#define IPL_DEPTH_SIGN 0x80000000
In meiner .pas Datei mache ich daraus...
Code:
...und bekomme vom Compiler die Warnung
const
IPL_DEPTH_SIGN: Integer = $80000000; "Konstantenausdruck verletzt untere Grenzen". Mache ich was falsch? Sollte mich die Warnung kratzen? Gruß, oXmoX |
Re: Seltsame Fehler in Delphi
Integer($80000000) ist nicht gut - das high bit ist das Vorzeichen - du definierst da (-0) und das mag der Compiler wohl nicht. Geht nicht Cardinal?
marabu oder DWORD... |
Re: Seltsame Fehler in Delphi
Zitat:
Laß den Typ ganz weg und entscheide bei der Verwendung ob ein Cast wirklich nötig ist. |
Re: Seltsame Fehler in Delphi
Für eine neue Frage bitte einen neuen Thread erstellen. Das hier hat wohl nichts mehr mit deinem ursprünglichen Problem zu tun.
|
Re: Seltsame Fehler in Delphi
Zitat:
Wenn dem so ist, dann brauche ich diese Konstante nicht wirklich. @Luckie: Sorry, kommt nicht wieder vor :wink: Edit: Hat $FFFF0000 eigentlich auch eine besondere Bedeutung? ...da schimpft der Compiler nämlich auch. Edit2: Klar schimpft er da ...das high-bit ist ja auch wieder gesetzt. :? |
Re: Seltsame Fehler in Delphi
Zitat:
|
Re: Seltsame Fehler in Delphi
O.K., ich schätze mein Problem hat sich erledigt. "Die Fehler" sind nun schon seit Wochen nicht mehr aufgetaucht :-D und mein Programm ist fast fertig. Ich nehme an, es lag an einem Fehler bei der Speicherfreigabe eines Pointers (dank Memproof gefunden).
Nocheinmal vielen Dank an alle, die geholfen haben. Gruß, oXmoX |
Re: Seltsame Fehler in Delphi
Zitat:
42 = $0000002A und -42 = $FFFFFFD6 oder auch not (42) + 1 marabu |
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:09 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz