Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Welchen Sinn hat diese Assert Zeile? (https://www.delphipraxis.net/178362-welchen-sinn-hat-diese-assert-zeile.html)

Der schöne Günther 3. Jan 2014 23:56

AW: Welchen Sinn hat diese Assert Zeile?
 
Aber ist das nicht eher ein Fall für Unit-Tests? Wenn ich (berechtigterweise) Angst hätte, durch laufende Arbeiten am Code seine (oder davon abhängige) Funktionsweisen ungewollt und unbewusst zu beinflussen sind das doch klassische Kandidaten für Tests?

Wenn ich mich nicht täusche, dann stoppt der Debugger bei einer fehlgeschlagenen Assertion durch die im Endeffekt geworfene EAssertionFailed dazu noch erstmal ganz woanders.

Wahrscheinlich ist es auch zu einem guten Teil Glaubens- und Geschmackssache, aber in meinem ganz persönlichen "Exception werfen vs. Assertion scheitern lassen"-Konflikt stehe ich mit dem Banner in der Hand klar auf der Seite der ganz normalen Exceptions. Die sowohl in Debug-, als auch Releasefassung geworfen werden.

Namenloser 4. Jan 2014 00:27

AW: Welchen Sinn hat diese Assert Zeile?
 
Unit-Tests und Assertions ergänzen sich meiner Meinung nach. Wenn ich beispielsweise so einen Baum teste, dann sagt der Unit-Test mir zwar, dass was schiefgelaufen ist, aber nicht wo. Und genau da helfen dann die Assertions.

jaenicke 4. Jan 2014 00:34

AW: Welchen Sinn hat diese Assert Zeile?
 
@Günther: Mit Unittests kannst du aber die Interna einer Klasse und deren Methoden nicht sinnvoll überwachen und dazu sind sie auch nicht da.

Assertions prüfen bei der Entwicklung die Einhaltung bestimmter Bedingungen, auch ggf. mit größeren Kosten an Rechnerleistung, was aber egal ist, da sie im Release nicht enthalten sind.
Wenn du an der Stelle stattdessen die Prüfungen immer durchführst, auch im Release, ist die Performance ggf. richtig im Keller.

Unittests, Assertions und Exceptions dienen schlicht teilweise anderen Zielen, haben unterschiedliche Nebeneffekte und sind daher nicht überall sinnvoll gegeneinander austauschbar.

Popov 4. Jan 2014 12:13

AW: Welchen Sinn hat diese Assert Zeile?
 
Danke für die Antworten. Es ist also so wie ich es mir gedacht habe - eine sinnvolle Zeile an sich, wenn aber einer im Internet in einem Standardbeispiel diese Zeile ganz am Anfang als erstes in einer Funktion eingebaut hat, dann ist es etwas übertrieben.

Furtbichler 4. Jan 2014 19:46

AW: Welchen Sinn hat diese Assert Zeile?
 
Zitat:

Zitat von Popov (Beitrag 1242084)
wenn aber einer im Internet in einem Standardbeispiel diese Zeile ganz am Anfang als erstes in einer Funktion eingebaut hat, dann ist es etwas übertrieben.

Jain, er implementiert 'fail fast' und sagt im Standardbeispiel, das der Parameter nicht nil sein soll, ohne das in einem Kommentar so zu schreiben. Ist das übertrieben oder eine Angewohnheit?

hoika 5. Jan 2014 07:50

AW: Welchen Sinn hat diese Assert Zeile?
 
Hallo,

schon diese Diskussion, die hoffentlich auch Delphi-Neulinge lesen,
zeigt mir, dass solch eine Zeile in einem "Standard-Beispiel" gut ist ...

Übrigens ist die Delphi-IDE selbst mit Asserts übersetzt,
Soviel zum Thema "Nicht in der Release-Version" verwenden.


Heiko

Popov 5. Jan 2014 08:46

AW: Welchen Sinn hat diese Assert Zeile?
 
Zitat:

Zitat von Furtbichler (Beitrag 1242152)
...und sagt im Standardbeispiel, das der Parameter nicht nil sein soll

Ok, das ein Objekt nicht nil sein darf, ist ja nicht ungewöhnlich. Es gibt viele Funktionen in denen nach nil abgefragt wird, um dann dementsprechend zu reagieren, z. B. raus aus der Funktion oder Objekt erstellen oder oder... Aber das ist ja was anderes.

Furtbichler 5. Jan 2014 10:49

AW: Welchen Sinn hat diese Assert Zeile?
 
Es wird zum frühestmöglichen Zeitpunkt sichergestellt, das die Methode ordnungsgemäß verwendet wird. Nicht der Folgefehler (durch Aufruf mit einem Nil-Objekt) ist das Problem/die Exception, sondern der Aufruf.

Zitat:

Zitat von hoika (Beitrag 1242180)
Übrigens ist die Delphi-IDE selbst mit Asserts übersetzt,
Soviel zum Thema "Nicht in der Release-Version" verwenden.

Wer sagt denn, das das aktuelle Delphi die 'Release'-Version ist? Im Release-Code wird das Assert nicht benötigt, denn im Code wird der Aufruf mit Nil ja erfolgeich durch Unit-Tests geprüft ;-) Wenn Emba Delphi mit Assertions ausliefert, spricht das doch sehr für die 'Qualität' und gegen Unittests.

In sicherheitsrelevantem Code (Flugzeug, Fahrzeugsteuerung etc.) bleiben Asserts erhalten bzw. werden durch 'echte' Abfragen ersetzt. Weil das zum 'fail fast' Paradigma gehört und dieser Code ruhig mit Hosenträgern, Gürteln und zusätzlichem Festtackern abgesichert sein soll.


Alle Zeitangaben in WEZ +1. Es ist jetzt 06:42 Uhr.
Seite 2 von 2     12   

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 by Thomas Breitkreuz