![]() |
Re: Custom compiler message beim Aufruf einer Methode möglic
Free ist nur Public und es wäre besser, wenn man das auch noch im Destructor prüft.
(Beispiel: siehe EOutOfMemory in der SysUtils) Warnungen kann man ignorieren. [edit] OK, nicht Destructos, sondern FreeInstance.
Delphi-Quellcode:
also am Einfachsten diese Beiden überschreiben.
uses SysConst, Dialogs;
procedure TForm1.FormCreate(Sender: TObject); var E: EOutOfMemory; begin E := EOutOfMemory.CreateRes(@SOutOfMemory); E.Free; ShowMessage('bin noch da: ' + E.Message); // und an das nötige private E.AllowFree:=True; kommt man nicht ran end;
Delphi-Quellcode:
in NewInstance prüfen ob es schon existiert und ansonsten eine Exception
class function NewInstance: TObject; virtual;
procedure FreeInstance; virtual; und in FreeInstance prüfen ob es freigegeben werden darf |
Re: Custom compiler message beim Aufruf einer Methode möglic
Da ich den Ansatz mit class constructor und class property gewählt habe, kommt auch das Überschreiben von NewInstance und FreeInstance leider nicht in Frage, da niemals ein Objekt der Singleton Klasse selber erzeugt wird.
|
Re: Custom compiler message beim Aufruf einer Methode möglic
OK, dann einfach nur NewInstance überschreiben, denn wenn da wirklich mal einer eine Instanz erzeugen will und dabei sämtliche Warnungen ignoriert, dann schmeißt du ihm darin einfach eine Exception entgegen. :zwinker:
dann ist das aber kein Singelton mehr. Singelton = nur maximal eine Instanz der Klasse exisitert |
Re: Custom compiler message beim Aufruf einer Methode möglic
Zitat:
![]() |
Re: Custom compiler message beim Aufruf einer Methode möglic
Wenn die Klasse nach außen wirklich nicht sichtbar sein soll,
dann kannst du auch ganz böse sein und alles auf einen Record umstellen. Von diesem kann man garantiert keine Instanz erstellen. :lol:
Delphi-Quellcode:
Wobei man hier auch teilweise komplett auf die interne Klasse verzichten könnte.
unit SingletonUnit;
interface type {T}Singleton = record class procedure DoSomething; end; implementation type TInternalSingleton = class constructor Create; procedure DoSomething; end; var FSingle: TInternalSingleton; constructor TInternalSingleton.Create; begin ... end; procedure TInternalSingleton.DoSomething; begin ... end; class procedure TSingleton.DoSomething; begin FSingle.DoSomething; end; initialization FSingle := TSingleton.Create; finalization FSingel.Free; end. |
Re: Custom compiler message beim Aufruf einer Methode möglic
Die Idee war eher folgende:
Delphi-Quellcode:
In einer anderen unit wird dann z.B. TFooSingleton = class(TSingleton<TFoo>) deklariert und auch nur diese Klasse nach außen freigegeben. Auch die unit Singleton sollte nicht im uses benutzt werden, sondern nur die, wo die konkrete Singleton-Klasse definiert wurde (in dem Beispiel TFooSingleton).
unit Singleton;
interface type TSingleton<T: class, constructor> = class private class var FInstance: T; class constructor Create; class destructor Destroy; public class function NewInstance: TObject; override; class property Instance: T read FInstance; end; implementation uses SysUtils; class constructor TSingleton<T>.Create; begin FInstance := T.Create; end; class destructor TSingleton<T>.Destroy; begin FInstance.Free; end; class function TSingleton<T>.NewInstance: TObject; begin raise Exception.CreateFmt('Instantiation of TSingleton<%s> not allowed', [T.ClassName]); end; end. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:57 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