![]() |
Verhindern von Instanzierung eines Objekts mit Create
Hallo Delphi Gemeinde
Meine erste Frage hier dreht sich um einen relativ komischen Wunsch, nicht so alltäglich. Ich habe eine Klasse gemacht, die alle Methoden static hat und alle Membervariablen mit class var deklariert hat. Das Ganze ist nach diesem Beispiel von ![]()
Delphi-Quellcode:
Nun ist es allerdings immer noch möglich, den Constructor mit Create aufzurufen. Um allen potenziellen Benutzern der Klasse klar zu machen, dass man davon keine eigenen Instanzen machen darf, möchte ich das aufrufen von Create verbieten. Ist das irgendwie möglich? :gruebel:
type
TMyClass = class strict private class var FX: Integer; strict protected // Note: accessors for class properties must be declared class static. class function GetX: Integer; static; class procedure SetX(val: Integer); static; public class property X: Integer read GetX write SetX; class procedure StatProc(s: String); static; end; TMyClass.X := 17; TMyClass.StatProc('Hello'); Beispiel
Delphi-Quellcode:
Danke und Gruss an die Welt
TMyClass.StatProc('Hello'); // soll funktionieren
myObj := TMyClass.Create; // soll nicht funktionieren |
Re: Verhindern von Instanzierung eines Objekts mit Create
|
Re: Verhindern von Instanzierung eines Objekts mit Create
Schmeiss einfach eine Exception im Konstruktor. Dann wird die Erstellung des Objektes abgebrochen und es ist wie gewünscht.
|
Re: Verhindern von Instanzierung eines Objekts mit Create
Das gefällt mir eben auch nicht. Ich möchte wenn schon einen Compiler-Fehler. Weil sonst vergisst plötzlich jemand die Exception ab zu fangen und zu behandeln. Dann gibts plötzlich unschöne Effekte...
Ich habe auch schon mit einem abstrakten Constructor probiert
Delphi-Quellcode:
Das gibt aber eben auch eine Exception und nicht einen Compiler-Fehler.
Constructor Create; virtual; abstract
|
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
Das Problem bei Delphi ist das die abstrakt-Definition nicht bei der Klassendefinition möglich ist sondern nur auf Methodenebene. |
Re: Verhindern von Instanzierung eines Objekts mit Create
Naja, ich habe mich nun entschieden, das ganze anders zu lösen. Und zwar habe ich ein globales Objekt erstellt (wird für Logging verwendet). So kann ich auch sicher sein, dass es das Objekt nur einmal gibt.
Danke jedenfalls für die Kommentare. Gruss |
Re: Verhindern von Instanzierung eines Objekts mit Create
Was passiert, wenn man einen privaten Konstruktor definiert?
// Edit: Ach vergesst es, grad den anderen Thread gesehen und gelesen.. Da wurde ja genau das versucht. |
Re: Verhindern von Instanzierung eines Objekts mit Create
Hi,
der Thread ist zwar schon etwas älter. aber irgendwie ist mir gerade dazu eine Idee gekommen: Ein abstrakter Konstruktor kann nicht aufgerufen werden! Das gibt sogar ne Warnung (sowie Exception zur Laufzeit), und mit DDevExtensions wird ein Fehler zur Compilezeit draus ;) Naja, aber ne bessere Idee hab ich dann doch nicht. Mfg FAlter |
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
|
Re: Verhindern von Instanzierung eines Objekts mit Create
Liste der Anhänge anzeigen (Anzahl: 1)
Hi,
ich dachte, es wurde eine Lösung gesucht, die nicht compiliert. Bitte, man muss nur Warnungen als Fehler interpretieren, und das geht mit ![]() Mfg FAlter |
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
|
Re: Verhindern von Instanzierung eines Objekts mit Create
Bin mit Delphi nicht mehr so am laufenden, aber in C# kämen folgende Möglichkeiten in Frage:
|
Re: Verhindern von Instanzierung eines Objekts mit Create
Hi,
ich sagte ja, eine bessere Idee hab auch ich nicht. Aber wenn der User keine DDevExtensions hat, sieht er trotzdem die Warnung (nur eben als Warnung), und da steht drin, dass der Konstruktor selbst abstrakt ist. Ein guter Programmierer sieht sich die Warnungen auch mal an, und spätestens dann bemerkt er seien Fehler. Bei strict private kommt nicht einmal eine Warnung :( Jedenfalls bin ich der Ansicht, dass ein abstrakter Konstruktor deutlich besser ist als ein privater. Wer sicher gehen will, zwingt dem Programmierer eben komische Parameter auf.
Delphi-Quellcode:
Aber darauf würde ich sogar verzichten.
type
TTest = class constructor Create(var Do_Not_Call_This_Constructor: TTest); virtual; abstract; end; Mfg FAlter |
Re: Verhindern von Instanzierung eines Objekts mit Create
Code:
Und wie wäre es in soeinem Fall garnicht erst eine Klasse zu verwenden?
type
TMyClass = [color=#ff0000]record[/color] strict private class var FX: Integer; strict protected // Note: accessors for class properties must be declared class static. class function GetX: Integer; static; class procedure SetX(val: Integer); static; public class property X: Integer read GetX write SetX; class procedure StatProc(s: String); static; end; ein Record hat Erstens keine Instanzen und Zweitens hat er in Delphi auch keinen Constructor. |
Re: Verhindern von Instanzierung eines Objekts mit Create
Was ist denn wenn man die Klasse selber als abstract deklariert ?!?!
|
Re: Verhindern von Instanzierung eines Objekts mit Create
Liest Du die oberen Beiträge?
Zitat:
|
Re: Verhindern von Instanzierung eines Objekts mit Create
class abstract
Classes, and not just methods, can be declared as abstract. type TAbstractClass = class abstract procedure SomeProcedure; end; ![]() |
Re: Verhindern von Instanzierung eines Objekts mit Create
Oh mann..
Das ist neu in Delphi 2007. Du hast wohl nicht geguckt, welche Delphi-Version der OP benutzt? |
Re: Verhindern von Instanzierung eines Objekts mit Create
Immer locker bleiben,
wollte ja nur aufzeigen dass es möglich ist. |
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
Die ![]() Zitat:
Und in der Tat kann ich in Delphi 2006 eine als 'sealed' gekennzeichnete Klasse erstellen, die sich auch wirklich nicht ableiten lässt. Nur 'abstract' muckt ein bissel rum. [OT] Desweiteren war Dein Umgangston gegenüber bennixview nicht gerade nett. Nur mal so angemerkt, im Zuge der hiesigen Diskussionen zu den Themen 'Neue Leute', 'Jeder hat eine Chance', 'Reizbarkeit'... Manchmal habe ich echt das Gefühl, dass hier einiges vertauscht wird. Der, der helfen will, kriegt eins auf den Deckel, wenns mal falsch ist (was es hier definitiv nicht war), und die wirklichen Nervensägen kriegen Zucker in den Arsch geblasen. [/OT] Edit: da ich ja auch manchmal etwas überreizt bin und mit meinen Interpretationen daneben haue - sollte ich Deine Äußerungen falsch verstanden haben - sorry. Ansonsten - denk mal drüber nach. |
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
Zitat:
Dort sind - wie die Überschrift Aussagt - alle Features gelistet, die in 2007 neu sind. Und zwar kumuliert seit Delphi 7 (weil das die am meisten eingesetzte Delphi-Version ist. Dass dort dann logischerweise auch wieder alte Features von Delphi 8, 2005 und 2006 drin stehen ist logisch, aber diese Liste ist so wie sie da steht nur Verbindlich für 2007. So, und nun genug des Offtopic. Zum Rest folgt im Laufe des Tages ne PN. |
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
Entschuldige bitte, aber willst Du mich für blöd verkaufen? Du widersprichst Dir selber auf ganzer Linie: Zitat:
Zitat:
Das ändert aber nichts an der Tatsache, dass eines dieser Features bereits in Delphi 8, 2005 und 2006 eingeführt worden sein kann, was bei 'abstract' wohl zutrifft, da es in D2006 verfügbar ist - und der OP hat D2006. Also war Deine Aussage Zitat:
Und spart Euch jeglichen Kommentar bzgl. dieses kleinen Ausrasters hier - aber wenn jemand meint, er müsse mich für doof verkaufen, nur wegen seiner scheinbaren Autorität als Moderator dieses Forums, dann platzt mir echt der Kragen. Von mir aus könnt Ihr mich nun verwarenen, rausschmeißen, oder sonst was. Aber so eine Nummer ziehst Du mit mir bitte nicht nochmal ab! Und mir dann mit Hinweis auf OT noch verbieten wollen, mich dazu zu äußern... Edit: Und wenn Du jetzt meinst, diesen meinen Beitrag hier löschen zu müssen, dann stellst Du Dir selber ein Armutszeugnis aus. [/OT] |
Re: Verhindern von Instanzierung eines Objekts mit Create
Dann Probiere doch mal aus ob Dein 2006er Compiler verhindert, dass Du eine Instanz einer abstrakten Klasse erzeugen kannst. Wenn er das wie der 2007er auch verhindern würde, dann hättest Du recht, und dieses feature gäbe es schon in 2006.
Dieses Feature gibt es aber - wie Du schnell herausfinden wirst - erst in Delphi 2007. Und jetzt erkläre mir bitte mal, wo ich Dich für Dumm verkaufe oder wo das schlicht und einfach falsch wäre. Ich glaub, ich bin echt im falschen Film. Edit: Und ich bin der Meinung, da wäre jetzt eine öffentliche Entschuldigung mehr als angebracht. |
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
Zitat:
Zitat:
Da nicht zu jedem Feature die Version angegeben ist, kann jeder von uns nur Vermutungen anstellen; es sei denn, man testet es. Zitat:
Und diese Aussage stellst Du als unwahr dar. Da es daran aber schlicht und einfach nichts dran zu rütteln gibt, was duch das 'sealed'-Beispiel auch belegt ist, komme ich mir von Dir verarscht vor - ganz einfach. Zitat:
|
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
|
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
Soweit ich mich erinnere, habe ich gesagt, dass das eine kumulierte Liste seit Delphi 7 ist. Und ich habe zudem gesagt, dass man abstrakte Klasse erst ab Delphi 2007 nicht mehr instanzieren kann. Weder die eine, noch die andere Aussage ist falsch. Die erste deckt sich zudem noch mit Deiner. Nochmal: Wieso kommst Du Dir dabei verarscht vor? Du behauptest doch, ich hätte das Gegenteil von dem gesagt, wass da oben bei mir schwarz auf weiss stehst? Ach.. mir wird das jetzt zu bunt. Soll sich jemand anderes aus dem Team oder Daniel darum kümmern. |
Re: Verhindern von Instanzierung eines Objekts mit Create
Hallo,
@s-off und phoenix: Vertragt euch wieder und trinkt zusammen ein Bier :wink: Wie ist den nun der Vorschlag von Himitsu mit dem "Record" anstelle "class" ? |
Re: Verhindern von Instanzierung eines Objekts mit Create
Hi,
Zitat:
Für diesen Thread hier (Klasse nur mit statischen Methoden) ist es also ok. Will man dagegen verhindern, dass eine Instanz einer abstrakten Basisklasse erstellt wird, so ist dies keine Lösung. Mfg FAlter |
Re: Verhindern von Instanzierung eines Objekts mit Create
Zitat:
Für beide Lösungsansätze kann man jede Delphi-Version für Win32 verwenden, und muss sich nicht auf Delphi-Compiler beschränken, die 'class static' unterstützen. Kurz: Ich halte die Fragestellung in diesem konkreten Fall für hinfällig, weil das Design an Compiler-Featuritis leidet. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:42 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