AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Trick zum Debuggen

Ein Thema von Luckie · begonnen am 12. Jul 2003 · letzter Beitrag vom 12. Jul 2003
Antwort Antwort
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#1

Trick zum Debuggen

  Alt 12. Jul 2003, 05:38
Hier ein kleiner Trick, der helfen kann beim Debuggen um den Fehjler aufzuspüren / einzugrenzen:

Als ersts fügt man am Anfang folgenden Kompilerschalter ein:
{$APPTYPE CONSOLE} Damit wird unsere Windows GUI Anwendung zu einer Konsolen-Anwendung, die ein Konsole öffnet mit unserem Anwendungsfenster. In dieses Konsolenfenster kann man dann mit sich writeln Meldungen ausgeben lassen. Hier mal ein kleines Beispiel:

Delphi-Quellcode:
unit Unit1;

{$APPTYPE CONSOLE}

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;

type
  TForm1 = class(TForm)
    Button1: TButton;
    procedure FormCreate(Sender: TObject);
    procedure Button1Click(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

function LastErrorMsgStr: String;
var
  szerror: array [0..255] of Char;
begin
  FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM, nil, GetLastError(), 0, szError,
    sizeof(szError), nil);
  writeln(String(szError));
end;

procedure TForm1.FormCreate(Sender: TObject);
begin
  writeln('OnCreate');
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  Messagebox(123456, 'Test', 'Test', 0);
  LastErrorMsgStr();
end;

end.
So das kann man jetzt noch etwas verfeiner. Es ist ja bekannt, dass Windows mit GetLastError den zu letzt im aufrufenden Thread aufgetretenen letzten Fehler zurück gibt. Das kann man dann so ein bauen:
writeln(GetLastError()); Da die meisten wohl die nummerischen Fehler Codes nicht im Kopf haben, habe ich eine kleine Funktion geschrieben, die den nummerischen Wert im Klartext liefert und ihn mit writeln in der Konsole ausgibt:
Delphi-Quellcode:
function LastErrorMsgStr: String;
var
  szerror: array [0..255] of Char;
begin
  FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM, nil, GetLastError(), 0, szError,
    sizeof(szError), nil);
  writeln(String(szError));
end;
Aufruf im Programm:
LastErrorMsgStr(); Siehe auch dazu die Button-Click-Prozedur.

Der Vorteil ist, dass man flüssig weiter testen kann, ohne ständig die Messageboxen von RaiseLastOSError() wegklicken zu müssen.

Der Tipp stammt übrigens von Assarbad.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Christian Seehase
(Co-Admin)

Registriert seit: 29. Mai 2002
Ort: Hamburg
11.116 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Trick zum Debuggen

  Alt 12. Jul 2003, 12:29
Moin Luckie,

und wer keine zusätzliche Funktion mit in sein Programm aufnehmen möchte, kann statt Deines LastErrorMsgStr auch SysErrorMessage aus den SysUtils verwenden.
Tschüss Chris
Die drei Feinde des Programmierers: Sonne, Frischluft und dieses unerträgliche Gebrüll der Vögel.
Der Klügere gibt solange nach bis er der Dumme ist
  Mit Zitat antworten Zitat
Benutzerbild von Motzi
Motzi

Registriert seit: 6. Aug 2002
Ort: Wien
598 Beiträge
 
Delphi XE2 Professional
 
#3

Re: Trick zum Debuggen

  Alt 12. Jul 2003, 13:14
Also ich mach das immer mit OutputDebugString - die Ausgaben tauchen dann im Event Log der IDE auf (Ctrl-Alt-V). Damit erspar ich mir die Konsole
Manuel Pöter
  Mit Zitat antworten Zitat
Antwort Antwort

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:23 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz