Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   If ...else - Abfrage mit Tücken (https://www.delphipraxis.net/182292-if-else-abfrage-mit-tuecken.html)

geesmith 15. Okt 2014 16:40

If ...else - Abfrage mit Tücken
 
Hallo zusammen

Es geht um eine If-Abfrage mit mehr als einem Check drin welche mit AND verbunden sind. Konkret um eine If-Afrage mit zwei Checks.

Ich habe mit Delphi 2009 folgenden Code geschrieben:
Delphi-Quellcode:
  if (FBITechEntryActive <> nil) and (FBITechEntryActive.AN8 <> cxCurrencyEdit_AN8.Value) then
  begin
    DoSomething;
Also wenn ein Objekt nicht nil ist, dann soll er eben von diesem Objekt noch den Wert mit einem anderen Wert vergleichen.

Diese Abfrage lief mal problemlos. Ich ging damals davon aus, dass Delphi erst den ersten Check macht und falls dieser nicht zutrifft der zweite Check gar nicht mehr ausführt. Dass dies fehlerfrei lief gab mir eigentlich recht... dachte ich.

Mittlerweile programmiere ich mit Delphi XE5 und plötzlich bekomme ich mit obigen Code eine Schutzverletzung, so dass ich den Code wie folgt umschreiben musste:
Delphi-Quellcode:
  if (FBITechEntryActive <> nil) then
  begin
    if FBITechEntryActive.AN8 <> cxCurrencyEdit_AN8.Value then
      DoSomething;
Es scheint, als ob er bei der ersten Abfrage den Vergleich "(FBITechEntryActive.AN8 <> cxCurrencyEdit_AN8.Value)" gemacht hat.

Nun meine Frage... wäre die If-Abfrage wie ganz oben eigentlich ok? Oder sollte sowas gar nicht erst gemacht werden?

mkinzler 15. Okt 2014 16:44

AW: If ...else - Abfrage mit Tücken
 
Ist die vollständige Boolean Auswertung aktiviert?
http://docwiki.embarcadero.com/RADSt...r-Direktive%29

Sir Rufo 15. Okt 2014 16:46

AW: If ...else - Abfrage mit Tücken
 
Das ist eine Option die man einstellen kann, ob der gesamte Ausdruck ausgewertet wird oder nur bis zum eindeutigen Ergebnis.

Helmi 15. Okt 2014 16:46

AW: If ...else - Abfrage mit Tücken
 
oder unter "Projekte --> Delphi-Compiler --> Compilieren"

DeddyH 15. Okt 2014 17:15

AW: If ...else - Abfrage mit Tücken
 
Wenn man die AND-Verknüpfung durch versxhachtelte If-Abfragen ersetzt, spielt diese Einstellung keine Rolle.

Der schöne Günther 15. Okt 2014 17:28

AW: If ...else - Abfrage mit Tücken
 
Interessant- Ich hatte neulich auch ein älteres Projekt in XE5 importiert und die vollständige Boolsche Auswertung war auch aktiviert. Ob da beim Konvertieren was falsch läuft?

Captnemo 15. Okt 2014 18:43

AW: If ...else - Abfrage mit Tücken
 
Lieber 2 If-Anweisungen als nur eine mit Eigenschaften eines Objects, das evtl. gar nicht vorhanden ist. Damit schießt man sich im Zweifelsfall nur in's Knie.
Mag zwar sein, dass es mit der entsprechenden Compileranweisung funktioniert, aber wenn man sich sowas angewöhnt, und in großen Projekten öfter macht....
ich würd sowas lieber generell nicht machen.

geesmith 15. Okt 2014 19:03

AW: If ...else - Abfrage mit Tücken
 
Super, Danke für eure Antworten. Jetzt bin ich gscheiter. :)

himitsu 15. Okt 2014 20:07

AW: If ...else - Abfrage mit Tücken
 
Zitat:

Zitat von Captnemo (Beitrag 1276074)
Mag zwar sein, dass es mit der entsprechenden Compileranweisung funktioniert,

Lieber doppelten Code?

Die vollständige boolische Auswertung ist ein Sonderfall und nicht der Standard.
Wenn man auch für Standardsachen überall Spezialbehandlungen einführt, dann wird die Arbeit schnell umfangreich und unnötig schwierig.

Delphi-Quellcode:
// besser niemals so
if Assigned(obj) and obj.IsActive then begin
  obj.MethodeA;
  obj.MethodeB;
  obj.MethodeC;
end;

// sondern so
if Assigned(obj) then
  if obj.IsActive then
    try
      if Assigned(obj) then
        obj.MethodeA;
    except
      ShowMessage('unnötige sinnlose Fehlermeldung, welche die originale Exception verschrottet');
    end;
if Assigned(obj) then
  if obj.IsActive then
    try
      if Assigned(obj) then
        obj.MethodeB;
    except
      ShowMessage('es könnte ja sein daß Exception-Objekt verschwindet');
    end;
if Assigned(obj) then
  if obj.IsActive then
    try
      if Assigned(obj) then
        obj.MethodeC;
    except
      ShowMessage('also besser nicht verwenden');
    end;
Es könnte ja sein das Objekt verschwindet zwischendurch. :roll:



Die Projektoptionen sind an einigen Stellen eh voll schrottig.
* solche Optionen haben global dort eigentlich nichts zu suchen (wenn man das benötigt, dann sollte man das ausschließlich lokal dort aktivieren, wo nötig)
* die Standardvorgaben sind teilweise auch Mist. (standardmäßig aktivierte Debug-DCUs :wall:)
* und eine Vorlage für neue Projekte kann man dort auch nicht mehr speichern.

mm1256 16. Okt 2014 07:17

AW: If ...else - Abfrage mit Tücken
 
Ich aktiviere die vollständige boolsche Auswertung aus og. Gründen auch nicht, sondern setze die Ausdrücke in Klammer und hatte noch nie Probleme damit:

Code:
 if ((FBITechEntryActive <> nil) and (FBITechEntryActive.AN8 <> cxCurrencyEdit_AN8.Value)) then
  begin
    DoSomething;

DeddyH 16. Okt 2014 07:32

AW: If ...else - Abfrage mit Tücken
 
Was soll die zusätzliche Klammerung bei nur 2 Audrücken denn bringen?

jaenicke 16. Okt 2014 07:40

AW: If ...else - Abfrage mit Tücken
 
Wenn für einen bestimmten Code eine bestimmte Einstellung der vollständigen boolschen Auswertung in die eine oder andere Richtung notwendig ist, dann aktiviere ich diese auch direkt davor oder deaktiviere sie (Direktive BOOLEVAL ON bzw. OFF). Auf diese Weise ist stets sichergestellt, dass der Code immer zuverlässig funktioniert egal in welchem Projekt mit welcher globalen Einstellung er benutzt wird.
Dazu kommt natürlich noch ein kurzer Kommentar warum das notwendig ist.

So braucht man auch keine Schachtelung stattdessen, die ggf. das ganze unübersichtlicher machen kann. Zudem fehlt dann die Möglichkeit ein gemeinsames else zu nutzen, so dass ggf. zusätzlicher und oft redundanter Code notwendig ist.

Zitat:

Zitat von mm1256 (Beitrag 1276114)
Ich aktiviere die vollständige boolsche Auswertung aus og. Gründen auch nicht, sondern setze die Ausdrücke in Klammer

Wenn du Pech hast, stolperst du dabei über einen Compilerfehler. Ich hatte mal den kuriosen Fall, dass eine überflüssige Klammerung dazu führte, dass der erzeugte Code falsch war. Leider hatte ich das damals aus Zeitmangel nicht dokumentiert oder gemeldet, so dass ich nicht prüfen kann, ob der Fehler in aktuellen Versionen noch besteht.

Sir Rufo 16. Okt 2014 07:43

AW: If ...else - Abfrage mit Tücken
 
@jaenicke :thumb:

himitsu 16. Okt 2014 09:32

AW: If ...else - Abfrage mit Tücken
 
Zitat:

Zitat von mm1256 (Beitrag 1276114)
Ich aktiviere die vollständige boolsche Auswertung aus og. Gründen auch nicht, sondern setze die Ausdrücke in Klammer und hatte noch nie Probleme damit:

Code:
 if ((FBITechEntryActive <> nil) and (FBITechEntryActive.AN8 <> cxCurrencyEdit_AN8.Value)) then
  begin
    DoSomething;

Das Klammersetzen hat hiermit absolut nichts zu tun.

Die "vollständige boolische Auswertung" bedeutet, daß alle Vergleiche geprüft werden, egal ob das Endergebnis bereits fest steht.
Kann man benutzten, wenn alle Funktionsaufrufe in dem "boolischen Ausdruck" ausgeführt werden müssen/sollen.

Bei
Delphi-Quellcode:
False and Irgendwas
ist mit False das Ergebnis bereits festgelegt und man muß garnicht erst gucken was Irgendwas macht.
Wäre Irgendwas eine Funktion oder Referenzauflösung, dann würde dieses nicht mehr ausgeführt, außer wenn man diese Option aktiviert hat.
Dann würde das zwar noch ausgeführt, auch wenn es auf das Ergebnis des boolischen Ausdrucks keinen Einfluss mehr hat.

p80286 16. Okt 2014 11:15

AW: If ...else - Abfrage mit Tücken
 
Zitat:

Zitat von Der schöne Günther (Beitrag 1276070)
Interessant- Ich hatte neulich auch ein älteres Projekt in XE5 importiert und die vollständige Boolsche Auswertung war auch aktiviert. Ob da beim Konvertieren was falsch läuft?

Da hat wohl jemand aus uralten TP-Zeiten was übernommen:evil:
Diese Verhalten ist mir allerdings auch schon über den Weg gelaufen, und es gab keine Compileranweisungen!

Gruß
K-H


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:15 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