Sök…


Exempel på medlarmönster i java

Medlarmönster definierar ett objekt (Mediator) som kapslar in hur en uppsättning objekt interagerar. Det möjliggör kommunikation mellan många och många.

UML-diagram:

Medlardiagram

Nyckelkomponenter:

Mediator: Definierar ett gränssnitt för kommunikation mellan kollegor.

Colleague : Är en abstrakt klass som definierar de händelser som ska kommuniceras mellan kollegor

ConcreteMediator : Implementerar kooperativt beteende genom att samordna Colleague och underhåller sina kollegor

ConcreteColleague : Implementerar anmälningsoperationerna som mottagits genom Mediator , som har genererats av andra Colleague

Ett verkligt exempel:

Du underhåller ett nätverk av datorer inom Mesh topologi.

Ett nätverk är en nätverkstopologi där varje nod överför data för nätverket. Alla nätnoder samarbetar i distributionen av data i nätverket.

Om en ny dator läggs till eller befintlig dator tas bort, bör alla andra datorer i det nätverket veta om dessa två händelser.

Låt oss se hur Medlarmönster passar in i det.

Kodavsnitt:

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);
    }
}

produktion:

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

Förklaring:

  1. Eagle läggs till i nätverket först genom registerhändelse. Inga meddelanden till andra kollegor eftersom Eagle är den första.
  2. När Ostrich läggs till nätverket meddelas Eagle : rad 1 för utmatning återges nu.
  3. När Penguin läggs till i nätverket har både Eagle och Ostrich fått ett meddelande: Linje 2 och Line 3 av utgången återges nu.
  4. När Eagle lämnade nätverket genom oregistrerad händelse har både Ostrich och Penguin meddelats. Linje 4 och rad 5 på utgången återges nu.


Modified text is an extract of the original Stack Overflow Documentation
Licensierat under CC BY-SA 3.0
Inte anslutet till Stack Overflow