Delphi-PRAXiS
Seite 3 von 3     123   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Frame: Button OnClick handler manchmal nicht zugewiesen? (https://www.delphipraxis.net/210570-frame-button-onclick-handler-manchmal-nicht-zugewiesen.html)

himitsu 18. Mai 2022 15:12

AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
 
Zitat:

Damit verbirgt man ...
Security through Obscurity :roll:


Im Idealfall hab ich so aber auch nur ein Uses, was ich irgendwie schon bissl übersichtlicher empfinde.


Im Interface ist es immer in der selben Reihenfolge.
In der Implementation könnte, selbst bei unverändertem Code, bei jedem Compilieren was in einer anderen Reihenfolge geladen werden, was bei einer Fehlersuche besonders viel Spaß macht.

Aber das Wichtigste, im Interface habe ich nie "ausversehn" mal unbemerkte Kreisreferenzen drin ... in der Implementation fällt dir das nie auf,
außer da unten steht nur das drin, was absichtlich dort steht, wegen einer bekannten Kreuz-/Kreisreferenz.

Uwe Raabe 18. Mai 2022 16:00

AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
 
Zitat:

Zitat von himitsu (Beitrag 1506028)
Security through Obscurity

Eher Information hiding.

Zitat:

Zitat von himitsu (Beitrag 1506028)
In der Implementation könnte, selbst bei unverändertem Code, bei jedem Compilieren was in einer anderen Reihenfolge geladen werden

Das kann nur bei zyklischen Abhängigkeiten passieren, aber die lassen wir ja nicht zu.

Zitat:

Zitat von himitsu (Beitrag 1506028)
im Interface habe ich nie "ausversehn" mal unbemerkte Kreisreferenzen drin ... in der Implementation fällt dir das nie auf,

Das ist genau das obige Argument mit der Faulheit. Bei einer sauberen Architektur entstehen erst gar keine Zyklen und zur Sicherheit gibt es ja Code-Checks, die das spätestens beim Einchecken monieren.

Aber ich denke, das Thema ist zumindest hier nun ausreichend diskutiert. Wir können das gerne an anderer Stelle vertiefen wenn du möchtest.

bernau 18. Mai 2022 17:28

AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
 
Zitat:

Zitat von himitsu (Beitrag 1506028)
Aber das Wichtigste, im Interface habe ich nie "ausversehn" mal unbemerkte Kreisreferenzen drin ... in der Implementation fällt dir das nie auf, außer da unten steht nur das drin, was absichtlich dort steht, wegen einer bekannten Kreuz-/Kreisreferenz.

Genau so. Das hat auch nichts mit Faulheit zu tun. Es ist lediglich eine Hilfe, das diese "schrecklichen" zirkulären Referenzen sich nicht einschleichen.

dummzeuch 18. Mai 2022 17:59

AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
 
Ich sehe das wie Uwe. Weiterer Vorteil: Änderungen an Units, die in der Implementation Uses-Liste stehen, erfordern kein Neuerstellen der sie verwendenden DCUs. Nicht, dass das bei einem One-Pass-Compiler groß in's Gewicht fiele.

Frickler 19. Mai 2022 08:54

AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
 
Btw: gibts eigentlich ein Tool, welches
  • Units, die im Interface-Teil angegeben werden, aber dann nur im Implementation-Teil verwendet werden, vom Interface- in den Implementation-Teil verschieben kann?
  • Units, die gar nicht verwendet werden, aus der jeweiligen Unit-Liste löschen kann?

Uwe Raabe 19. Mai 2022 09:07

AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
 
Peganza's Pascal Analyzer (vermutlich auch die Lite Version) gibt das zumindest als Report aus. Eine automatische Änderung ist auch nicht immer sinnvoll, da gelegentlich die IDE auf bestimmte Units im Interface-Teil pocht und auch andere Gründe gegen eine Verlagerung in den Implementation-Teil sprechen können (z.B. Reihenfolge von WinApi.Windows und System.Sysutils o.ä.).

Für die manuelle Verschiebung vom einen in den anderen Teil verwende ich immer die entsprechende Funktion (Shift-Ctrl-Alt-Up/Down innerhalb einer uses-Anweisung) im MMX Code Explorer.

himitsu 19. Mai 2022 12:09

AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
 
"gar nicht verwendet" ist auch nicht immer zutreffend.

Ich kann eine Unit einbinden, welcher im Initalization sich irgendwo registriert, was ich dann später benötige,
aber dennoch nirgendwo anschließend im Code direkt auf diese Unit direkt zugreifen.

Automatisch rausgeworfen darf also garnicht werden.

Frickler 19. Mai 2022 14:36

AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
 
Zitat:

Zitat von himitsu (Beitrag 1506077)
Ich kann eine Unit einbinden, welcher im Initalization sich irgendwo registriert, was ich dann später benötige, aber dennoch nirgendwo anschließend im Code direkt auf diese Unit direkt zugreifen.

Sollte so etwas in meinen Projekten vorkommen, erstelle ich eine eigene Unit "indirectimports.pas" oder so, die diese Units einbindet, und die ich dann einbinde. So weiß ich, dass ich das nicht rauswerfen darf.

Uwe Raabe 19. Mai 2022 15:20

AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
 
Man kann diese Units auch explizit im Projekt einbinden. Die Units in der DPR werden überwiegend sowieso dort nicht direkt verwendet.

In letzter Zeit spendiere ich solchen Units wenn möglich eine Register/Unregister Prozedur, die dann bei Bedarf aufgerufen werden.


Alle Zeitangaben in WEZ +1. Es ist jetzt 22:31 Uhr.
Seite 3 von 3     123   

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