8 Stimmen

Dependency Injection, Injektion eines "injizierbaren" Objekts (Dienst) in ein newable (Entität)

Beim Schreiben von Code sollten wir in der Lage sein, zwei große Gruppen von Objekten zu identifizieren:

  • Injektionsmittel
  • Newables

http://www.loosecouplings.com/2011/01/how-to-write-testable-code-overview.html

http://misko.hevery.com/2008/09/30/to-new-or-not-to-new/

  • Injizierbare Objekte sind Objekte (Dienste), die in ihren Konstruktoren Abhängigkeiten offenlegen. Diese Abhängigkeiten werden in der Regel mithilfe eines IoC-Containers aufgelöst; diese Objekte können in ihren Konstruktoren nur nach anderen injizierbaren Objekten fragen

  • Newable sind Objekte, die auch Abhängigkeiten in ihren Konstruktoren offenlegen, aber Newables können nur nach anderen newable Objekten (Entities, Value Objects) fragen, ein weiteres Merkmal von newable Objekten ist, dass sie keinen Verweis auf ein injizierbares Objekt enthalten sollten

Aber beim Schreiben von Code müssen wir oft einen Dienst (injectable) in eine Entität (newable) "injizieren".

Ich habe gedacht, dass vielleicht eine Service-Abhängigkeit in einem newable Objekt ist besser tun es auf Methodenebene, aber das klingt wie eine Menge Arbeit zu tun.... nur über die Auflösung der Abhängigkeiten jedes Mal, wenn eine Methode aufgerufen wird.... gut das riecht wie wir den Service Locator Anti-Muster verwenden müssen

Ich habe das Problem auf folgende Weise gelöst:

  • Erstellen einer Schnittstelle mit einer Methode, die die Abhängigkeit offenlegt (der Dienst wird in dieser Methode verwendet)

  • Erstellen Sie eine Erweiterungsmethode für die Schnittstelle und platzieren Sie sie in einem anderen Namensraum, vielleicht in einer anderen Baugruppe, und verpacken Sie den Aufruf der ursprünglichen Methode, indem Sie die Abhängigkeit mit einem Service Locator auflösen

Auf diese Weise haben wir eine konsequente Trennung zwischen newable und injectable Objekten mit der Möglichkeit, Dienste in unseren newables einfach zu verwenden

  • Was meinen Sie dazu?
  • Die Verwendung des Service Locators in einer Erweiterungsmethode wird als schlechte Praxis angesehen?
  • Wie würden Sie den Aufruf der Erweiterungsmethode unit-testen?

4voto

WW. Punkte 22847

Aber wenn wir Code schreiben, müssen wir oft einen Dienst "injizieren (injectable) in eine Entität (newable)

Dies ist nicht der Fall - wenn Sie die Notwendigkeit sehen, dies zu tun, dann gibt es eine Funktionalität, die in der Entität existiert, die in einem Dienst sein sollte.

Nehmen wir an, Ihr Newable lautet ShoppingCart und Ihre Injektionslösung ist eine Datenbank repository . Sie möchten dies tun können:

// somehow cart already got the repository
cart.save();

Nun, Sie machen es falsch. Stattdessen müssen Sie die Dinge umdrehen und tun:

respository.save( cart );

Wenn Sie eine Situation schildern könnten, in der Sie das Bedürfnis haben, dies zu tun, könnten wir die Einzelheiten dieser Situation besprechen.

CodeJaeger.com

CodeJaeger ist eine Gemeinschaft für Programmierer, die täglich Hilfe erhalten..
Wir haben viele Inhalte, und Sie können auch Ihre eigenen Fragen stellen oder die Fragen anderer Leute lösen.

Powered by:

X