Szukaj…


Publikuj-Subskrybuj w Javie

Wydawca-subskrybent to znana koncepcja, biorąc pod uwagę rozwój serwisów YouTube, Facebook i innych serwisów społecznościowych. Podstawowa koncepcja polega na tym, że istnieje Publisher który generuje treść, oraz Subscriber który korzysta z treści. Za każdym razem, gdy Publisher generuje treść, każdy Subscriber jest powiadamiany. Subscribers mogą teoretycznie subskrybować więcej niż jednego wydawcę.

Zwykle między wydawcą a subskrybentem znajduje się ContentServer który pomaga w przekazywaniu wiadomości

public class Publisher {
    ...
    public Publisher(Topic t) {
        this.topic = t;
    }

    public void publish(Message m) {
        ContentServer.getInstance().sendMessage(this.topic, m);
    }
}

public class ContentServer {
    private Hashtable<Topic, List<Subscriber>> subscriberLists;

    private static ContentServer serverInstance;

    public static ContentServer getInstance() {
        if (serverInstance == null) {
            serverInstance = new ContentServer();
        }
        return serverInstance;
    }

    private ContentServer() {
        this.subscriberLists = new Hashtable<>();
    }
    
    public sendMessage(Topic t, Message m) {
        List<Subscriber> subs = subscriberLists.get(t);
        for (Subscriber s : subs) {
            s.receivedMessage(t, m);
        }
    }

    public void registerSubscriber(Subscriber s, Topic t) {
        subscriberLists.get(t).add(s);
    }

public class Subscriber {
    public Subscriber(Topic...topics) {
        for (Topic t : topics) {
            ContentServer.getInstance().registerSubscriber(this, t);
        }
    }
    
    public void receivedMessage(Topic t, Message m) {
        switch(t) {
            ...
        }
    }
}

Zwykle wzorzec projektowy pub-sub jest wdrażany z myślą o widoku wielowątkowym. Jedna z bardziej powszechnych implementacji widzi każdego Subscriber jako osobny wątek, a ContentServer zarządza pulą wątków

Prosty przykład pub-sub w JavaScript

Wydawcy i subskrybenci nie muszą się znać. Po prostu komunikują się za pomocą kolejek wiadomości.

(function () {
        var data;

        setTimeout(function () {
            data = 10;
            $(document).trigger("myCustomEvent");
        }, 2000);

        $(document).on("myCustomEvent", function () {
            console.log(data);
        });
})();

Tutaj opublikowaliśmy niestandardowe zdarzenie o nazwie myCustomEvent i zasubskrybowaliśmy to wydarzenie. Więc nie muszą się znać.



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