Delphi-PRAXiS
Seite 1 von 2  1 2      

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;


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:51 Uhr.
Seite 1 von 2  1 2      

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