![]() |
AW: Automatische Problem-Erkennung
Zitat:
|
AW: Automatische Problem-Erkennung
Ich habe mal eine komplette Unit erstellt. In dieser Variante bekomme ich auch mit Delphi 11 einen EInvalidPointer Fehler. Was genau Delphi in der Procedure "DoSomething" macht ist für mich noch nicht so richtig nachvollziehbar. Ob diese Kombination in einem normalen Programm so vorkommen kann weiß ich nicht. Bei mir hatte ich dies noch nicht. Ich sehe hier auch bei Delphi selbst keinen Fehler. Wenn ich Unsinn programmiere, dann bekomme ich auch ein Unsinniges Ergebnis.
Delphi-Quellcode:
unit Unit1;
interface uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs; type TForm1 = class(TForm) procedure FormCreate(Sender: TObject); private FMyVal: String; public procedure DoMore; procedure DoSomething(const sVal:String); end; var Form1: TForm1; implementation {$R *.dfm} procedure TForm1.DoMore; var Val: String; begin DoSomething(FMyVal); end; procedure TForm1.DoSomething(const sVal: String); var Val: String; begin FMyVal := ''; //ohne diese Zeile gibt es keinen Fehler Val := sVal; end; procedure TForm1.FormCreate(Sender: TObject); begin FMyVal := 'XXX'; //ohne diese Zeile gibt es keinen Fehler DoMore; end; end. |
AW: Automatische Problem-Erkennung
Es ist halt in unserem Programm genau so vorgekommen und ich habe das für hier nur auf die wesentlichen Eckpunkte zusammen gekürzt.
Das der Fehler nur kommt, wenn man ihn zuvor mit einem Wert beschreibt ging aus meinem Beispiel nicht hervor, da aber der Parameter ein const ist, war es eigentlich auch klar, dass er vorher "initialisiert" sein muss. Ist er in unserem Programm übrigens. Ja, Delphi macht hier genau das, was es soll, es optimiert den Aufruf indem es die Referenz übergibt und nicht den Speicher kopiert. Ja, wenn ich das const weg lasse (was wir dann auch getan haben) kopiert er den Wert wieder und es gibt keinen Fehler mehr an der Stelle. Nein, ich hätte trotzdem gerne dass der Compiler sich beschwert, wenn eine Variable übergeben wird, per const-Ref-Dings, und diese in der Funktion selbst beschrieben wird. Meinetwegen kann man diese Prüfung auch per Schalter aktivieren, wenn diese Zusatzprüfung zu lange dauert. Ja, ich weiß, dass es etwas (aber meines Erachtens nach nicht so viel) aufwendiger ist, wie zu prüfen ob der Const-Paramter innerhalb der Methode beschrieben wird. Naja, wird wohl nicht kommen, also Augen auf bei const-Parametern und nochmal 5 Minuten länger selbst nachdenken. |
AW: Automatische Problem-Erkennung
Ich kann deinen Punkt mit dem Compiler verstehen. Allerdings verstehe ich nicht, warum man der Funktion einer Klasse einen (privaten) Parameter dieser Klasse als Argument übergibt? Auf den Parameter kann doch sowieso innerhalb der Funktion zugegriffen werden?
|
AW: Automatische Problem-Erkennung
Ganz einfach, weil die Funktion teils von woanders mit anderen Parametern aufgerufen wird nur in diesem einen Aufruf wird genau der aktuelle Wert gebraucht. ;-)
Ich habe das Gefühl ihr denkt zu kompliziert. 😅 |
AW: Automatische Problem-Erkennung
Die Kapselung ohne äußere Werte in Funktionen ist auch in Klassen sehr sinnvoll, weil der Ablauf viel besser nachvollziehbar ist. Ich lagere solche Funktionen aber auch gerne aus der Klasse aus in eigene Toolklassen, aber das macht natürlich auch nicht immer Sinn.
Die Problematik hatte ich auch schon einmal im Debugger suchen müssen bei fremdem Code. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:29 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 by Thomas Breitkreuz