[Java] 观察者模式简述

模式定义:定义了对象之间的一对多依赖,让多个观察者对象同时监听某一个主题对象,当主题对象发生变化时,他的所有依赖者都会收到通知并且更新
[Java] 观察者模式简述_第1张图片
依照这个图,简单的写一个代码

package Section1.listener;

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

public class ObserverTest {
    public static void main(String[] args) {
        Suject suject = new Suject();
        //把观察者1,2塞到容器里面
        Task1 task1 = new Task1();
        Task2 task2 = new Task2();
        suject.addObserver(task1);
        suject.addObserver(task2);

		//对观察者下达一个 new task 通知
        String msg = "new task";
        suject.notifyObserver(msg);
    }
}

class Suject{
    //容器
    List<Observer> container = new ArrayList<>();
    //add
    public void addObserver(Observer observer){
        container.add(observer);
    }
    //remove
    public void removeObservce(Observer observer){
        container.remove(observer);
    }
    //通知
    public void notifyObserver(Object object){
        for (Observer item : container) {
            item.update(object);
        }
    }
}

interface Observer{
    void update(Object object);
}

//观察者1
class Task1 implements Observer{
    @Override
    public void update(Object object) {
        System.out.println("Task1 get " + object);
    }
}

//观察者2
class Task2 implements Observer{
    @Override
    public void update(Object object) {
        System.out.println("Task2 get " + object);
    }
}

观察者模式的优点是:

  1. 符合开闭原则
  2. 可以在运行时建立对象之间的联系

应用:

  1. JDK
  2. java.util.Observable
  3. Spring

下面是Spring中的应用代码

//相当于上面案例的Observer
@FunctionalInterface
public interface ApplicationListener<E extends ApplicationEvent> extends EventListener {
   //相当于update
   void onApplicationEvent(E var1);

   static <T> ApplicationListener<PayloadApplicationEvent<T>> forPayload(Consumer<T> consumer) {
       return (event) -> {
           consumer.accept(event.getPayload());
       };
   }
}

他的发布者是ApplicationEventMulticaster

你可能感兴趣的:(java,观察者模式,设计模式)