AGB  ·  Datenschutz  ·  Impressum  







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

Frage zum "is"-Operator

Ein Thema von QStorm · begonnen am 23. Jan 2014 · letzter Beitrag vom 27. Jan 2014
Antwort Antwort
Seite 3 von 4     123 4      
QStorm

Registriert seit: 28. Jun 2008
46 Beiträge
 
#21

AW: Frage zum "is"-Operator

  Alt 24. Jan 2014, 07:50
Das Gegenstück zu instanceof ist nun mal is und macht genau das was du beschreibst. Vielleicht hast du ganz falsche Erwartungen davon, was da passiert?
Eben nicht, denn "instanceof" prüft ob das referenzierte Objekt zuweisungskompatibel zu einer Klasse ist. "is" hingegen prüft lediglich, ob die Referenz/Pointer zuweisungskompatibel ist (wie man in meinem Beispiel schön sieht). "TObject.InheritsFrom" macht genau das was ich brauche.

Ich hab mal dein Beispiel von Anfang (ein bisschen abgeändert) getestet:
Ich habe dein abgeändertes Beispiel ausgeführt. Die Ausgabe ist jedoch anders, als du schreibst:
Code:
TStringList
TRUE
  Mit Zitat antworten Zitat
QStorm

Registriert seit: 28. Jun 2008
46 Beiträge
 
#22

AW: Frage zum "is"-Operator

  Alt 24. Jan 2014, 07:57
@QStorm
Wenn man weiß, was man macht, bzw. was man zulässt, dann ist das kein Problem.
Leider kann man das in komplexen Projekten insbesondere in Zusammenspiel mit externen Bibliotheken nicht immer wissen/überschauen.

In dem Beispiel mag das vielleicht noch gehen aber wie du schreibst gibt es 1000 Möglichkeiten, die du bestimmt auch nicht immer im Kopf hast.

OK vielen Dank nochmal für die Hilfe.

P.S.: Der Bauer kann schwimmen, ist nur nicht an eine Badehose voller Blei gewöhnt.
  Mit Zitat antworten Zitat
Furtbichler
(Gast)

n/a Beiträge
 
#23

AW: Frage zum "is"-Operator

  Alt 24. Jan 2014, 08:08
Was glaubt ihr wohl, was rauskommt, wenn ich über einen Besenstiel eine Maske von Justin Bieber stülpe? Eben. Vollkommener Trash. In Delphi:
Delphi-Quellcode:
if TJustinBieber(BesenStiel) is TJustinBieber then
  writeln('Wer hätte das gedacht');
Das ist der sog. 'harte Karsten' (oder engl: hard casting), und der funktioniert immer, daher ist das auch ziemlich dreist, so etwas zu tun und man muss schon wissen, was man macht. Praktisch ist der harte Karsten eigentlich nur, wenn man Speicherbereiche interpretieren will.

Bei Objekten verwendet man den 'as' Operator, der fragt nämlich freundlich nach (bzw. prüft) ob der Besenstiel überhaupt Willens und in der Lage ist, den Justin Bieber zu machen, was er natürlich nicht ist (einerseits ist der Besenstiel viel zu intelligent und zweitens liegt es nicht in seiner Natur, zu singen und sich daneben zu benehmen).

Aber nehmen wir mal, sagen wir, den Wendler und fragen ihn aber:
Delphi-Quellcode:
if (DerWendler Is TJustinBieber) then // hier kann der harte Karsten wieder ran
   TJustinBieber(DerWendler).SingUnsEinen();
Die Variante   (DerWendler as TJustinBieber).SingUnsEinen() würde mit einem invaliden Karsten antworten (EInvalidCastException), falls ER (der Wendler) uns wider Erwarten den Bieber Justin nicht machen kann, was sehr unwahrscheinlich ist, denn vom Niveau her sollte das schon passen.

Ach: Und zum eigentlichen Problem:

Das Zwischenspeichern von Eigenschaften einer anderen Klasse, während diese verändert wird, ist schlicht und ergreifend falsch. Das 'ActiveControl' der Form gibt zu jedem Zeitpunkt korrekt wieder, welches Control den Fokus hat und daher sollte man es auch so verwenden. Alles(!) andere ist schlicht und ergreifend fahrlässig.

PS: Der Bauer sollte sich erstmal an die Strandregel halten und überhaupt eine Badehose tragen.
  Mit Zitat antworten Zitat
QStorm

Registriert seit: 28. Jun 2008
46 Beiträge
 
#24

AW: Frage zum "is"-Operator

  Alt 24. Jan 2014, 08:51
@Furtbichler: Danke für die (wenn auch etwas zu sehr ausgeschmückte) Erklärung zu "as".
P.S.: Der Bauer ist dabei sich an die (an anderen Stränden weitaus besser verfassten) Strandregeln zu halten. Das ist jedoch ein Lernprozess und nicht von heute auf morgen geschehen.
  Mit Zitat antworten Zitat
Gushiken

Registriert seit: 23. Jan 2007
12 Beiträge
 
#25

AW: Frage zum "is"-Operator

  Alt 24. Jan 2014, 09:54
@Furtbichler: Großartig. Ganz großes Kino Auch wenn DerWendler vielleicht ein schlechtes Beispiel ist... Der macht doch alles um nicht ganz von der Bildoberfläche zu verschwinden, also wird es niemals einen invaliden Karsten geben
Eine sehr amüsante und gute (!) Erklärung vom Unterschied zwischen as und dem harten Karsten.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#26

AW: Frage zum "is"-Operator

  Alt 24. Jan 2014, 10:19
PS: Der Bauer sollte sich erstmal an die Strandregel halten und überhaupt eine Badehose tragen.
Aber dann kommt ja nicht die Bay(Instance)watch-Dame mit den blonden Beinen und den langen Hupen vorbei
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.027 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#27

AW: Frage zum "is"-Operator

  Alt 24. Jan 2014, 16:18
Um mal wieder zum Ursprungsproblem zu kommen.

Ich kann das bei mir mit der DevExpress 13.1.12 nicht nachstellen, dort zeigt bei einem leeren Grid ActiveControl auf ein TcxGridSite Control (was von TWinControl abgeleitet ist). Ich vermute also einen Bug in DevExpress, denn etwas, was nicht von TWinControl erbt in ActiveControl zu packen dürfte unzulässig sein.

P.S. Nachdem ich diesen 10 Jahre(!) alten KB Artikel gefunden habe, denke ich, das wird kein Bug in DevExpress sein.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight

Geändert von Stevie (24. Jan 2014 um 16:24 Uhr)
  Mit Zitat antworten Zitat
QStorm

Registriert seit: 28. Jun 2008
46 Beiträge
 
#28

AW: Frage zum "is"-Operator

  Alt 24. Jan 2014, 16:47
Um mal wieder zum Ursprungsproblem zu kommen.

Ich kann das bei mir mit der DevExpress 13.1.12 nicht nachstellen, dort zeigt bei einem leeren Grid ActiveControl auf ein TcxGridSite Control (was von TWinControl abgeleitet ist). Ich vermute also einen Bug in DevExpress, denn etwas, was nicht von TWinControl erbt in ActiveControl zu packen dürfte unzulässig sein.

P.S. Nachdem ich diesen 10 Jahre(!) alten KB Artikel gefunden habe, denke ich, das wird kein Bug in DevExpress sein.
Hallo,

Danke für den Link. Sehr interessant.

Das Problem ist ein anderes: Ich habe mir eine Referenz auf das aktive Control geholt (via TForm.ActiveControl). Danach wurde die UI geleert. Das aktive Control wurde dabei abgeräumt, was dazu führt, dass die Referenz auf Datenmüll im Speicher zeigt.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#29

AW: Frage zum "is"-Operator

  Alt 24. Jan 2014, 16:58
So etwas nennt sich dangling pointer oder wilder Zeiger. Den erkennt man auch mit einer Assigned-Abfrage nicht, da er ja weiterhin zugewiesen ist, auch wenn das Zielobjekt nicht mehr existiert. Aus diesem Grund muss man mit mehreren Referenzen auf dasselbe Objekt immer sehr vorsichtig sein oder sie wenn möglich gleich ganz vermeiden.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von JamesTKirk
JamesTKirk

Registriert seit: 9. Sep 2004
Ort: München
604 Beiträge
 
FreePascal / Lazarus
 
#30

AW: Frage zum "is"-Operator

  Alt 25. Jan 2014, 10:17
Das Gegenstück zu instanceof ist nun mal is und macht genau das was du beschreibst. Vielleicht hast du ganz falsche Erwartungen davon, was da passiert?
Eben nicht, denn "instanceof" prüft ob das referenzierte Objekt zuweisungskompatibel zu einer Klasse ist. "is" hingegen prüft lediglich, ob die Referenz/Pointer zuweisungskompatibel ist (wie man in meinem Beispiel schön sieht). "TObject.InheritsFrom" macht genau das was ich brauche.
Dann guck dir mal die Implementierung von is in FPC an:

Delphi-Quellcode:
    function fpc_do_is(aclass : tclass;aobject : tobject) : boolean;[public,alias: 'FPC_DO_IS']; compilerproc;
      begin
         fpc_do_is:=assigned(aobject) and assigned(aclass) and
           aobject.inheritsfrom(aclass);
      end;
Ich hab mal dein Beispiel von Anfang (ein bisschen abgeändert) getestet:
Ich habe dein abgeändertes Beispiel ausgeführt. Die Ausgabe ist jedoch anders, als du schreibst:
Code:
TStringList
TRUE
Eventuell kann es sein, dass der Compiler intfobjvar is TInterfacedObject vereinfacht zu Assigned(intfobjvar) , weil er davon ausgeht, dass in einer Variable vom Typ TInterfacedObject nur eine Instanz vom Typ TInterfacedObject oder eines seiner Nachfahren sein kann...
Kannst du dir mal bitte noch das Ergebnis von obj is TInterfacedObject ausgeben lassen? Da sollte dann, falls meine Vermutung zutrifft, False bei rauskommen.

Gruß,
Sven
Sven
[Free Pascal Compiler Entwickler]
this post is printed on 100% recycled electrons
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 3 von 4     123 4      


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:14 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