Szukaj…


Przykład wzoru mediatora w java

Wzorzec Mediator definiuje obiekt (Mediator), który opisuje sposób interakcji zestawu obiektów. Umożliwia komunikację wielu do wielu.

Diagram UML:

Diagram mediatora

Kluczowe komponenty:

Mediator: Definiuje interfejs do komunikacji między kolegami.

Colleague : Jest to klasa abstrakcyjna, która określa zdarzenia, które mają być komunikowane między Kolegami

ConcreteMediator : Realizuje zachowania kooperacyjne poprzez koordynację obiektów Colleague i utrzymanie współpracowników

ConcreteColleague : Realizuje operacje powiadomienia otrzymane za Mediator , które zostały wygenerowane przez innego Colleague

Przykład z prawdziwego świata:

Utrzymujesz sieć komputerów w topologii Mesh .

Sieć kratowa to topologia sieci, w której każdy węzeł przekazuje dane do sieci. Wszystkie węzły siatki współpracują w zakresie dystrybucji danych w sieci.

W przypadku dodania nowego komputera lub usunięcia istniejącego komputera wszystkie pozostałe komputery w tej sieci powinny wiedzieć o tych dwóch zdarzeniach.

Zobaczmy, jak pasuje do niego wzór Mediatora.

Fragment kodu:

import java.util.List;
import java.util.ArrayList;

/* Define the contract for communication between Colleagues. 
   Implementation is left to ConcreteMediator */
interface Mediator{
    void register(Colleague colleague);
    void unregister(Colleague colleague);
}
/* Define the contract for notification events from Mediator. 
   Implementation is left to ConcreteColleague
*/
abstract class Colleague{
    private Mediator mediator;
    private String name;
    
    public Colleague(Mediator mediator,String name){
        this.mediator = mediator;
        this.name = name;
    }
    public String toString(){
        return name;
    }
    public abstract void receiveRegisterNotification(Colleague colleague);
    public abstract void receiveUnRegisterNotification(Colleague colleague);    
}
/*  Process notification event raised by other Colleague through Mediator.   
*/
class ComputerColleague extends Colleague {
    private Mediator mediator;
    
    public ComputerColleague(Mediator mediator,String name){
        super(mediator,name);
    }
    public  void receiveRegisterNotification(Colleague colleague){
        System.out.println("New Computer register event with name:"+colleague+
        ": received @"+this);
        // Send further messages to this new Colleague from now onwards
    }
    public  void receiveUnRegisterNotification(Colleague colleague){
        System.out.println("Computer left unregister event with name:"+colleague+
        ":received @"+this);
        // Do not send further messages to this Colleague from now onwards
    }
}
/* Act as a central hub for communication between different Colleagues. 
   Notifies all Concrete Colleagues on occurrence of an event
*/
class NetworkMediator implements Mediator{
    List<Colleague> colleagues = new ArrayList<Colleague>();
    
    public NetworkMediator(){
    
    }
    
    public void register(Colleague colleague){
        colleagues.add(colleague);
        for (Colleague other : colleagues){
            if ( other != colleague){
                other.receiveRegisterNotification(colleague);
            }
        }
    }
    public void unregister(Colleague colleague){
        colleagues.remove(colleague);
        for (Colleague other : colleagues){
            other.receiveUnRegisterNotification(colleague);
        }
    }
}

public class MediatorPatternDemo{
    public static void main(String args[]){
        Mediator mediator = new NetworkMediator();
        ComputerColleague colleague1 = new ComputerColleague(mediator,"Eagle");
        ComputerColleague colleague2 = new ComputerColleague(mediator,"Ostrich");
        ComputerColleague colleague3 = new ComputerColleague(mediator,"Penguin");
        mediator.register(colleague1);
        mediator.register(colleague2);
        mediator.register(colleague3);
        mediator.unregister(colleague1);
    }
}

wynik:

New Computer register event with name:Ostrich: received @Eagle
New Computer register event with name:Penguin: received @Eagle
New Computer register event with name:Penguin: received @Ostrich
Computer left unregister event with name:Eagle:received @Ostrich
Computer left unregister event with name:Eagle:received @Penguin

Wyjaśnienie:

  1. Eagle jest dodawany do sieci na początku poprzez rejestrację zdarzenia. Brak powiadomień dla innych kolegów, ponieważ Eagle jest pierwszym.
  2. Kiedy Ostrich jest dodawany do sieci, Eagle jest powiadamiany: Wiersz 1 wyjścia jest teraz renderowany.
  3. Kiedy Penguin jest dodawany do sieci, zarówno Eagle , jak i Ostrich zostali powiadomieni: Linia 2 i Linia 3 wyjścia są teraz renderowane.
  4. Kiedy Eagle opuścił sieć w wyniku wyrejestrowania zdarzenia, zarówno Ostrich , jak i Penguin zostali powiadomieni. Wiersz 4 i wiersz 5 wyniku są teraz renderowane.


Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow