This article introduces the observer pattern of traffic java design pattern, which defines a one-to-many dependency relationship between objects so that when each object changes state. The following is an introduction to the observer pattern of Java design patterns through class diagrams and example codes. Friends who are interested should take a look.
Definition: Define a one-to-many dependency relationship between objects, so that when each When an object changes state, all objects that depend on it are notified and updated automatically.
Type: Behavioral class pattern
Class diagram:
## In software systems, there is often such a requirement: if an object When the state changes, some objects related to it must also make corresponding changes. For example, we want to design a right-click menu function. As long as you right-click the mouse within the valid area of the software, a menu will pop up; for another example, we want to design an automatic deployment function, just like when developing eclipse, as long as the file is modified , eclipse will automatically deploy the modified files to the server. These two functions have a similarity, that is, one object must monitor the other object at all times, and as soon as its status changes, it must take corresponding actions. In fact, there are many solutions that can achieve this, but there is no doubt that using the observer mode is a mainstream choice.The structure of the observer pattern
In the most basic observer pattern, it includes the following four roles:abstract class Subject { private Vector<Observer> obs = new Vector<Observer>(); public void addObserver(Observer obs){ this.obs.add(obs); } public void delObserver(Observer obs){ this.obs.remove(obs); } protected void notifyObserver(){ for(Observer o: obs){ o.update(); } } public abstract void doSomething(); } class ConcreteSubject extends Subject { public void doSomething(){ System.out.println("被观察者事件反生"); this.notifyObserver(); } } interface Observer { public void update(); } class ConcreteObserver1 implements Observer { public void update() { System.out.println("观察者1收到信息,并进行处理。"); } } class ConcreteObserver2 implements Observer { public void update() { System.out.println("观察者2收到信息,并进行处理。"); } } public class Client { public static void main(String[] args){ Subject sub = new ConcreteSubject(); sub.addObserver(new ConcreteObserver1()); //添加观察者1 sub.addObserver(new ConcreteObserver2()); //添加观察者2 sub.doSomething(); } }
Observer 1 receives the information and processes it. Observer 2 receives the information and processes it. We can see from the running results that we only called the Subject method, but at the same time the related methods of the two observers were called at the same time. Take a closer look at the code. It is actually very simple. It is nothing more than associating the Observer class in the Subject class and traversing the Observer's update method in the doSomething method.
Advantages of the observer pattern
## There is a slight relationship between the observer and the observed , and are abstractly coupled, making it easier for both to extend.
The observer pattern is a commonly used trigger mechanism. It forms a trigger chain and processes the methods of each observer in turn. But at the same time, this is also a shortcoming of the observer mode. Because it is a chain trigger, when there are many observers, performance issues are more worrying. Moreover, in the chain structure, it is easier for circular reference errors to occur, causing the system to freeze.
Summary
In the Java language, there is an interface Observer, and its implementation class Observable, for observers Roles are often realized. We can check the usage of these two classes in the jdk api documentation.
Friends who have done VC++, JavaScript DOM or AWT development are amazed by their event processing. Once you understand the observer pattern, you will have a certain understanding of the principles of the event processing mechanism. If you want to design the function of an event triggering processing mechanism, using the observer pattern is a good choice. The event processing DEM (Delegation Event Model) in AWT is implemented using the observer pattern.
The above is the detailed content of Specific analysis of the observer pattern in Java design patterns. For more information, please follow other related articles on the PHP Chinese website!