Java 代码实例解析设计模式之监听者模式

网友投稿 270 2022-11-28

Java 代码实例解析设计模式之监听者模式

代码展示

Main:测试类

ObServer:每个被监听的对象实现该接口,重写该方法,完成自己的业务

public interface ObServer {

/**

* 当某一个被监控的对象发生变化时

* 所有实现该方法处理方法

*/

void exceptionHandler();

}

Subject:监听者容器

public interface Subject {

/**

* 添加被观察对象

*/

void add(ObServer obServer);

/**

* 通知所有被观察者完成自己的 exceptionHandler 方法

*/

void notifyAllSubject();

}

SubjectHandler:监听者容器的实现类

public class SubjectHandler implements Subject {

/**

* 存放被监听对象

*/

private static final List SUBJECTS = Collections.synchronizedList(new LinkedList<>());

@Override

public void add(ObServer subject) {

SUBJECTS.add(subject);

}

@Override

public void notifyAllSubject() {

SUBJECTS.forEach(ObServer::exceptionHandler);

}

}

Thread1、Thread2 测试对象

模拟两个线程对数据库操作,若Threa1执行时出异常了,那么终止所有线程并对其回滚。

Threa1:

public class Thread1 implements ObServer, Runnable {

@SneakyThrows

@Override

public void run() {

System.out.println("thread1 run");

Thread.sleep(1000);

System.out.println("t1 end");

}

@SneakyThrows

@Override

public void exceptionHandler() {

System.out.println("thread1 rollback.....");

}

}

Thread2:

public class Thread2 implements ObServer, Runnable {

private static Thread CURRENT_THREAD;

private static volatile boolean FLAG = false;

@SneakyThrows

@Override

public void run() {

CURRENT_THREAD = Thread.currentThread();

System.out.println("thread2 running");

int count = 0;

while (!FLAG) {

System.out.println(count);

count++;

}

System.out.println("thread2 end");

}

@SneakyThrows

@Override

public void exceptionHandler() {

FLAG = true;

CURRENT_THREAD.interrupt();

System.out.println("thread2 rollback.....");

}

}

测试Demo

public static void main(String[] args) throws InterruptedException {

// 创建监听容器

Subject subject = new SubjectHandler();

Thread1 thread1 = new Threadhttp://1();

Thread2 thread2 = new Thread2();

subject.add(thread1);

subject.add(thread2);

ComplefnpBgiWMFWtableFuture.supplyAsync(() -> {

new Thread(thread1).start();

try {

Thread.sleep(10);

int a = 1 / 0; // 模拟线程1报错

} catch (InterruptedException e) {

e.printStackTrace();

}

return true;

}).exceptionally((error) -> {

subject.notifyAllSubjhttp://ect();

return false;

});

CompletableFuture.supplyAsync(() -> {

new Thread(thread2).start();

return true;

}).exceptionally((error) -> {

subject.notifyAllSubject();

return false;

});

// main thread await

Thread.sleep(60 * 1000);

}

测试结果

在 java.util 包下提供了Observable(监听容器)和 Observer接口(被监听者),用法跟我们完全一致,只需实现Observer的update方法,把每个Observer子类添加到监听容器中。

注意:在调用监听容器的通知所有servers时首先调用一下其setChanged方法

将changed变为true(默认flase)

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:qsort快排c语言和c++应用
下一篇:IOS --关于粘贴板 ,剪切板 ,UILabel的复制
相关文章

 发表评论

暂时没有评论,来抢沙发吧~