![]() |
AW: Interface richtig umgesetzt?
Zitat:
Ich denke Sir Rufo bringt es hier auf den Punkt: Zitat:
|
AW: Interface richtig umgesetzt?
Danke für die Antworten. Ich habe das alles jetzt mal umgesetzt und die Parameter in den Konstruktor gepackt. Das kann so nicht richtig sein.
Nochmal ganz konkret: Ja, ich rufe nur noch SendMessage() auf und die ganze Magie passiert in der implementierenden Klasse, weil mich das nicht interessiert was da vor sich geht. Okay. Doch wenn die Queue nicht existiertm, muss sie erst angelegt werden. Dann muss ich doch sagen können, wie sie angelegt werden soll. Parameterübergabe entweder im Konstruktor oder garnicht. Richtig? Im Interface bei Send/Receive kann ich sie auch nicht übergeben, da die Send-Parameter bei MSMQ andere sind, also bei anderen Queues oder via TCP. Also müssten sie alle im Konstruktor übergeben werden - auch die, die vllt. gerade garnicht benötigt werden. Oder muss ich mich dann auf Standard-Werte festlegen. Wenn eine Queue also nicht existiert, wird sie halt immer mit den von mir in der implementierenden Klasse festgelegten Standardwerten festgelegt. Also zB immer nicht transaktionell und nie weltlesbar. Nun aber zur Umsetzung: Dies wären die möglichen Parameter: MSMQ Create: Pathname, IsTransactional, IsWorldReadable MSMQ Open: Formatname, Access (MQ_READ_ACCESS etc..), ShareMode MSMQ Send: Subj, Body, DestinationQueue, Transaction MSMQ Receive: Transaction, WantDestinationQueue, WantBody, ReceiveTimeout, WantConnectorType
Delphi-Quellcode:
Ich habe verstanden, dass sich das implementierende Objekt um alles kümmern soll. Aber ich muss doch irgendwie Einfluss darauf haben, wie es die Queue im Notfall erstellen soll.
IMy_MQReceiver = interface
['{EECD3A9D-D9BC-4644-9D69-DADE10E65ED2}'] function ReceiveMessage(): String; end; IMy_MQSender = interface ['{5C3F02B1-2E73-4500-9CD3-02EAFEDB332C}'] function SendMessage(subject, msg: string): Boolean; end; TMQBroker = (mqMS, mqActiveMQ); TMy_MSMQ = class(TInterfacedObject, IMy_MQSender, IMy_MQReceiver) private public constructor Create(createPathName: String; createTransactional, createWorldReadable: Boolean; openAccess, openShareMode: LongInt; openFormatName: String; readTransaction: LongInt; readWantBody: Boolean; readTimeout; sendDestQueue: IMSMQQueue3; sendTransaction: LongInt); destructor Destroy(); function ReceiveMessage(): String; function SendMessage(Subject, msg: String): Boolean; end; // Und so könnte dann das Erstellen des Objektes aussehen: procedure TForm1.Button4Click(Sender: TObject); var mq: TMy_MSMQ; begin mq:=TMy_MSMQ.Create('meineNeueQueue', false, false, MQ_READ_ACCESS, MQ_DENY_SHARE, '.\Private\meineNeueQueue', 0, true, INFITE, nil, 0); end; Habe mich gerade länger damit beschäftigen können und verschiedene Methoden ausprobiert. Bin jetzt gerade etwas verwirrt ;) |
AW: Interface richtig umgesetzt?
Bis auf die Tatsache, dass du eine Schreib-Lese-Queue erzeugen möchtest ist das doch alles richtig. Ich wüsste keinen Fall, wo ich in ein und derselben Queue lesen und schreiben möchte. Queues sind One-To-One Verbindungen. Eine Nachricht in einer Queue wird von einem Empfänger empfangen. Will ich an mehrere Empfänger die gleiche Nachricht senden, dann muss die Nachricht auch in mehrere Queues.
Warum sollte es falsch sein, der implementierenden Klasse alles benötigte an die Hand zu geben um zu funktionieren? Mal abgesehen, dass es für dich ungewohnt ist anscheinend nicht alles in der Hand zu haben, wo siehst du in deiner Anwendung das konkrete Problem? Zeig doch mal etwas halbwegs konkretes, wo du beim Benutzen des Interfaces den Wunsch verspüren würdest, z.B. den Namen der Queue zu ändern, oder die Queue auf Transaktion umzustellen. BTW Das passt aber nicht
Delphi-Quellcode:
Bei SendMessage hast du Subject und Message aber bei ReceiveMessage gibt es nur einen String zurück. Was kommt denn da? Subject, Message oder beides zusammengewürfelt?
IMy_MQReceiver = interface
['{EECD3A9D-D9BC-4644-9D69-DADE10E65ED2}'] function ReceiveMessage(): String; end; IMy_MQSender = interface ['{5C3F02B1-2E73-4500-9CD3-02EAFEDB332C}'] function SendMessage(subject, msg: string): Boolean; end; |
AW: Interface richtig umgesetzt?
Zitat:
Zitat:
Zitat:
Aber danke für diese Hinweise - hätte ja wirklich ein echter Fehler sein können. Die Interfaces etc werden dann später auch nicht mehr "TMY..." lauten ;) --- Aber wenn wir schon dabei sind: Kannst du mir nochmal folgendes erklären Zitat:
Vielen Dank an alle! |
AW: Interface richtig umgesetzt?
Zum einen muss man ja auch nicht nur einen Konstruktor haben und zum anderen kann man auch eine Factory nehmen.
Für eine minimalistische Queue brauchst du z.B. nur 2 Parameter, dann erstell dir einen Konstruktor mit diesen 2 Parametern und für die superduper Gedöns-Queue benötigst du 42 Parameter, jo, dann eben noch so einen, und evtl. noch ein paar weitere. Eine Factory hilft immer dann, wenn man sehr viele Instanzen benötigt mit sehr vielen gleichen und wenigen variablen Parametern. Dann erzeuge ich die Factory mit den gleichbleibenden Parametern und hole mir die Instanzen über die Angabe der noch fehlenden, aber eben variablen Parameter. Schon bleibt das hübsch übersichtlich.
Delphi-Quellcode:
Sieht ja schon einfacher aus :)
TMSMQQueueFactory = class
constructor Create( Server, { ganz viele Parameter } ); function CreateSendQueue( const QueueName : string ) : ISendQueue; function CreateReceiveQueue( const QueueName : string ) : IReceiveQueue; end; Das Beispiel mit dem Postamt wird bei dir jetzt nicht so richtig passen, es ging mehr um die Möglichkeiten. Ein Regelwerk könnte ja darin bestehen, dass z.B. Chat-Nachrichten in eine andere Queue kommen, als andere Nachrichten. Dann muss dein Postamt z.B. den Nachrichtentypen erkennen und sucht sich die passende Queue für die Chat-Nachrichten heraus und versendet darüber. |
AW: Interface richtig umgesetzt?
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:41 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