0

次のコードを見つけました。

public static void main(String args[]) {
        Producer producer = new Producer();
        producer.start();
        new Consumer(producer).start();
    }
}
class Producer extends Thread {
    static final int MAXQUEUE = 5;
    private Vector<String> messages = new Vector<String>();

    public void run() {
        try {
            while (true) {
                putMessage();
                sleep(1000);
            }
        } catch (InterruptedException e) {
        }
    }

    private synchronized void putMessage() throws InterruptedException {

        while (messages.size() == MAXQUEUE)
            wait();
        messages.addElement(new java.util.Date().toString());
        notify();
    }

    public synchronized String getMessage() throws InterruptedException {
        notify();
        while (messages.size() == 0)
            wait();
        String message = (String) messages.firstElement();
        messages.removeElement(message);
        return message;
    }
}

class Consumer extends Thread {
    Producer producer;

    Consumer(Producer p) {
        producer = p;
    }

    public void run() {
        try {
            while (true) {
                String message = producer.getMessage();
                System.out.println("Got message: " + message);
                sleep(2000);
            }
        } catch (InterruptedException e) {
        }
    }

したがって、私が理解しているように、メッセージの受け渡しは、共有リソースを使用するだけではなく、上記のサンプル参照のように、あるオブジェクトから別のオブジェクトへの通信に使用されます。私は正しいですか?

4

2 に答える 2

1

パブリッシュ/サブスクライブ パターンに従っている場合は、何らかのメッセージキューが必要です。Producer はメッセージをキューに入れ、Consumer はキューのメッセージを読み取ります。

メッセージングのポイントは、プロデューサー/コンシューマーが互いに直接参照する必要はなく、キューを介してのみ通信することです。

于 2012-04-05T12:54:18.300 に答える
0

なんで自分で書くの?ActiveMQなどの既存の Java Message Service (JMS) ソリューションを使用できます。インプロセスで実行し、オブジェクト間でメッセージを渡すことができます。

于 2012-04-05T10:46:10.553 に答える