wait-notify 实现多线程交叉备份
来源:互联网 发布:ubuntu wget安装 编辑:程序博客网 时间:2024/05/21 22:47
一、任务
创建20个线程,其中10个线程是将数据备份到 A 数据库中,另外10 个线程将数据备份到 B 数据库中,并且备份 A 数据库和 备份 B 数据库的是交叉运行的。
二、实现
1、实现备份 A 数据库和备份 B 数据库的 task。
/** * Description: 当flag=true的时候备份 A 数据库 * 当flag=false的时候备份 B数据库 以此实现交叉备份 */public class TaskBackup{ volatile private boolean flag=false;// 采用volatile关键字,使变量于多个线程之间可见 synchronized public void backupA(){ //synchronized 关键字,避免多个线程对同一对象的修改,导致“脏读” try { //记住,这里的判断一定要用while 而不是用if,为什么呢?因为存在多个线程,不止备份B数据库的线程在等待,可能备份A数据库的线程也在等待,如果用if //可能会导致 同类唤醒同类的 情况导致线程的“假死”。 while (flag==false){ this.wait(); } System.out.println(Thread.currentThread().getName()+"正在备份 A 数据库!");//模拟备份数据库 flag=false; this.notifyAll();//唤醒所有等待的线程,当然这里并不会唤醒backupA 的线程,原因在于,backupA的线程这个时候又做了一个while判断,导致线程继续在等待了,而只有backupB的线程被唤醒了 } catch (InterruptedException e) { e.printStackTrace(); } } synchronized public void backupB(){ try { while (flag==true){ this.wait(); } System.out.println(Thread.currentThread().getName()+"正在备份 B 数据库!");//模拟备份数据库
flag=true; this.notifyAll(); } catch (InterruptedException e) { e.printStackTrace(); } } }
2、分别创建线程执行 备份任务
public class ThreadBackupA extends Thread{ private TaskBackup taskPackup; public ThreadBackupA(TaskBackup taskPackup) { this.taskPackup = taskPackup; } @Override public void run() { super.run(); taskPackup.backupA(); }}
public class ThreadBackupB extends Thread{ private TaskBackup taskPackup; public ThreadBackupB(TaskBackup taskPackup) { this.taskPackup = taskPackup; } @Override public void run() { super.run(); taskPackup.backupB(); }}
3、执行任务查看结果
public class Run{ public static void main(String[] args) { TaskBackup taskPackup=new TaskBackup(); for (int i=0;i<20;i++){ ThreadBackupA threadBackupA=new ThreadBackupA(taskPackup); ThreadBackupB threadBackupB=new ThreadBackupB(taskPackup); threadBackupA.start(); threadBackupB.start(); } }}
三、结语
觉得这个例子写得特别棒,所以特地记录了一下。它把 诸如 线程notify过程中 wait条件发生改变、同类唤醒同类导致的“假死”问题 等,都做了一个很好的概括应用和解决。笔主资历尚浅,说的不好的地方,还请不吝指教,谢谢!
阅读全文
0 0
- wait-notify 实现多线程交叉备份
- wait/notify 实现多线程交叉备份
- Java多线程之线程间通信--等待(wait)/通知(notify)机制,等待/通知之交叉备份实例
- 多线程的wait()/notify()
- Java多线程wait/notify
- 多线程-notify和wait
- wait与notify实现多线程的协调通信
- Java 多线程实现生产者消费者问题(wait/notify)
- 多线程 : 使用 wait 和 notify 实现进程间同步通信
- 多线程之生产者消费者基本实现——wait/notify
- java多线程: wait/notify机制
- java多线程wait() ,notify() notifyAll()
- java多线程中的wait/notify
- 多线程中的wait与notify
- 【多线程_basic】 wait/notify/notifyAll
- 多线程wait-notify;notifyall.sleep
- java 多线程 wait notify sleep
- 多线程中wait(),notify(),notifyAll()
- RESTFeel: 一个企业级的API管理&测试平台。RESTFeel帮助你设计、开发、测试您的API
- DFiddler:A HTTP Packets Listener一个简易版的手机端的Fiddler。
- 六条“黑客伦理”(hacker ethic)
- 黑客的价值观
- 《Springboot极简教程》SpringBoot plus Mongodb开发企业级restfeel接口测试平台
- wait-notify 实现多线程交叉备份
- Myeclipse2015把web项目添加至tomcat中,添加列表中却没有想要添加的项目
- 《Springboot极简教程》问题解决:Springboot启动报错 Whitelabel Error Page: This application has no explicit mapping for
- 《Springboot极简教程》问题解决:javax.servlet.ServletException: Circular view path [login]: would dispatch back to the current handler URL
- 原声JS判断程序运行平台Pc OR Mobile
- 《Springboot极简教程》继承WebMvcConfigurerAdapter: 一行代码写Controller
- LeetCode 105. Construct Binary Tree from Preorder and Inorder Traversal
- 搭建Maven(搭建+问题笔记)
- 《Springboot极简教程》问题解决:Idea解决Gradle库依赖冲突问题:Detected both log4j-over-slf4j.jar AND slf4j-log4j12.jar on the class path, preempting