Fragen zu Assert
Ich bin jetzt in einem Code über Assert gestolpert. In meinem Buch steht dazu (frei übersetzt):
Zitat:
Zitat:
Delphi-Quellcode:
Aber was bringt das?
Assert(FileExists(Filename));
|
Re: Fragen zu Assert
Hallo Luckie,
Stichworte zu diesem Thema sind: Design by Contract, invariants, how to use assertions, precondition postcondition. Die Programmiersprache Eiffel biete die Zusicherung von Invarianten sogar direkt als Sprachkonstrukt eiffel invariants. |
Re: Fragen zu Assert
Ich hab nur folgendes gefunden:
EAssertionFailed ist die Exception-Klasse. Sie wird aufgerufen, wenn an die Prozedur Assertion der bool'sche Ausdruck False übergeben wird. Ich schätz mal dass du dann einfach ne Message bekommst...so ungefähr
Delphi-Quellcode:
Ob das nun dafür gedacht ist oder net... ka :)
Assert(Liste <> nil, 'Keine Einträge vorhanden');
|
Re: Fragen zu Assert
Code:
Statt das irgenwo ne Exception rausgeworfen wird, sagt der dir, dass genau an der einen Stelle, wo du totsicher von true ausgingst, soch false rauskam. d.h. du solltest davor schaun, was schiefgelaufen ist. ist also wie gesagt zum debuggen gut. Beispiel:
Use Assert as a debugging tool to test that conditions assumed to be true are never violated. Assert provides an opportunity to intercept an unexpected condition and halt a program rather than allow execution to continue under unanticipated conditions.
Delphi-Quellcode:
...so hab ich es verstanden...
procedure TForm1.FormCreate(Sender: TObject);
var a: boolean; begin a := false; assert(a); IchGehFreiwilligInDieHoelle(not a); end; |
Re: Fragen zu Assert
Hi,
wir haben gerade noch folgenden Link aufgegabelt und der dokumentiert das sehr schön: http://www.idev.ch/index.php?option=...tid=4&Itemid=3 ...:cat:... |
Re: Fragen zu Assert
Der große Vorteil von Asserts ist das sie per Compilerschalter deaktivierbar sind. D.h. während der Programmierung arbeitet man mit Assert(FileExists(), 'Datei nicht vorhanden'); und wenn alles ordentlich funktioniert wird im Productioncode ohne DebugInfo und Assertitions recompiliert. Der Compiler erzeugt dann keinerleit Code mehr für die Asserts.
Gruß Hagen |
Re: Fragen zu Assert
Ich hab noch diesen Link gefunden, verweist allerdings auf ein Word Dokument:
http://mitglied.lycos.de/AJSchmidt/D...ehlersuche.doc Geht auch wieder um die Fehlersuche mit Assert ;) |
Re: Fragen zu Assert
Also, ich habe mal etwas rumgespielt und getestet. Betrachten wir mal folgenden Code:
Delphi-Quellcode:
Mit der Annahme dass es diese Datei nicht gibt. Dann bricht Assert den Programmablauf ab und gibt eine Fehlermeldung aus. Das könnte man jetzt auch mit if's und try-excepts lösen. Aber der Unterschied ist der:
procedure TForm1.Button1Click(Sender: TObject);
begin Assert(FileExists('c:\test.txt'), 'Datei gibbet nitt'); end; Zitat:
Fazit: In Testversionen kann ein Assert für den Entwickler hilfreicher sein, als eine normale Fehlermeldung genriert durch eine Exception oder eine Messagebox in einem else-Zweig einer if-Bedingung. |
Re: Fragen zu Assert
Zitat:
|
Re: Fragen zu Assert
Zitat:
|
Re: Fragen zu Assert
:gruebel: Das heisst, dass bei einer "fertigen", also kompilierten, EXE diese Fehlermeldungen auftauchen und anzeigen wo im Quelltext dieser Fehler aufgetreten ist? :roll:
Was kann mir das bringen??? MfG Florian :hi: |
Re: Fragen zu Assert
Der Zweck von Assertions liegt in der Zusicherung von Zuständen. Also zB so triviale Dinge wie
Delphi-Quellcode:
(Postconditions) bzw beim Testen von PreConditions
function Uppercase(const AString: string): string;
begin //do some logic here Assert(Length(Result)=Length(AString), 'Length of Result differs from input'); Assert(IsEveryCharACapital(Result), 'Not every char of Result is a capital'); end;
Delphi-Quellcode:
Interessant ist dieses Konstrukt zur "Dokumentation" und Zusicherung von Zwischenständen, damit Dritte schneller erkennen und sicherstellen können, dass die Fehlerquelle nicht in fremdem Code zu suchen ist, weil sonst die Assertions "angeschlagen" hätten:
procedure FillRect(const ACanvas: TCanvas; const APoint: TPoint;
const AnotherPoint: TPoint); begin Assert(Assigned(ACanvas), 'Canvas cannot be nil'); Assert((APoint.X<AnotherPoint.X) and (APoint.Y<=AnotherPoint.Y), 'First Point must be "smaller" than second'); //do some logic here end;
Delphi-Quellcode:
Dinge, die die Programmlogik beeinflussen sollten nicht als Assertions formuliert werden und auch im zweiten skizzierten Fall ist es fragwürdig, ob ACanvas nicht lieber mit einer Exception "gesichert" werden sollte... Aber hier gibt es unterschiedliche Meinungen...
// doing foo now
SomeComplicatedLogig(WithAComplexFormular, AndSomeMoreParams); Assert(EnsureFooWasDone, 'Foo was not done'); // doing bar now AndAgainSome; VeryObfuscatedCode; AndEvenMoreCodeThatIsNotObvious; Assert(EnsureBarWasDone, 'Bar was not done'); |
Re: Fragen zu Assert
D.h. Assert ist nur so was ähnliches wie try ... except? :roll:
MfG Florian :hi: |
Re: Fragen zu Assert
Zitat:
In der Tat ist ein Stack durch Exceptionwrapping bei ausreichend fein granulierten Klassen idR hilfreicher... |
Re: Fragen zu Assert
:roll: Also für Fehlerkorrektur "vor Ort" !?!
Ich brauch sowas zum Glück noch nicht... :) MfG Florian :hi: |
Re: Fragen zu Assert
Zitat:
Beide Konstrukte verfolgen aber unterschiedliche Ansätze: Während bei Assertions (siehe zweites Posting) Invarianten und Vor-/Nachbedinungen nach dem "Vetragskonzept" zugesichert werden und anderfalls ein Abbruch (hier: in Form einer Exception) initiiert wird,
Code:
sollen Exceptions den Entwickler auf denkbare Fehlersituationen aufmerksam machen und die Behandlung eben dieser unvermeidbaren Situationen von der tatsächlichen Logik entkoppeln, um verwirrende Konstrukte zu vermeiden und klar zu kommunizieren was passieren könnte, wenn man eine Methode verwendet:
//hier gilt mit Sicherheit A
ArbeitenUnterDieserPrämisse; //hier gilt nun mit Sicherheit B und A
Code:
EineMethode; //könnte Fehler A verursachen
EineAndereMethode; //könnte Fehler A oder B verursachen
Code:
//in diesem Abschnitt:
VerwendenVon EineMethode; Verwendenvon EineAndereMethode; //könnten Fehler A oder B auftreten! |
Re: Fragen zu Assert
Wie lauten die Compilerschalter zum Deaktivieren denn`?`?
|
Re: Fragen zu Assert
Rat mal wo du das findest und unter welchen Stichwort.
|
Re: Fragen zu Assert
Zitat:
Code:
Ausschnitt posten können...
$ASSERTIONS ON/OFF (long form)
$C +/- (short form) |
Re: Fragen zu Assert
Das war ein virtueller Schlag auf den Hinterkopf und du weißt doch, dass selbige das Denkvermögen erhöhen. :zwinker:
|
Re: Fragen zu Assert
Schon, aber nicht alle Leute wollen selber denken! :mrgreen:
|
Re: Fragen zu Assert
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:10 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