当现在不适合这个操作,或者没有必要进行这个操作时,就直接放弃而回去
这就是Balking Pattern
主要有4个类
Data 代表要保存的数据
SaverThread 定时存盘线程 模拟word的定时保存
ChangerThread 用户线程 模拟用户在修改文档,文档修改后这两个线程会去抢着保存到文件
Main 就是main啦
直接上代码吧
/**
* @author 徐良永
* @date 2013-6-5下午5:02:38
*/
public class Data {
private String content;
private boolean changed = false;
public Data(){}
public synchronized void setContent(String content){
this.content = content;
this.changed = true;
}
public synchronized void save(){
if(!changed){ //没变化 直接返回
return;
}
doSave();
changed = false;
}
private void doSave(){
//TODO write file
System.out.println(Thread.currentThread().getName() + "call doSave, content = " + content);
}
}
/**
* 定时存盘线程
* @author 徐良永
* @date 2013-6-5下午3:07:44
*/
public class SaverThread extends Thread{
private Data data;
public SaverThread(Data data){
super("SaverThread");
this.data = data;
}
public void run(){
try {
while(true){
data.save();
Thread.sleep(2000);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
public class ChangerThread extends Thread {
private Data data;
private Random random = new Random();
public ChangerThread(Data data){
super("ChangerThread");
this.data = data;
}
public void run(){
try {
for (int i = 0; i < 1000; i++) {
data.setContent("No." + i);
Thread.sleep(random.nextInt(1000));
data.save();
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
public class Main {
public static void main(String[] args) {
Data data = new Data();
new SaverThread(data).start();
new ChangerThread(data).start();
}
}
分享到:
相关推荐
Java中的Balking模式是一种多线程设计模式,它主要用于处理多个线程可能对同一资源进行操作的情况,但当发现其他线程已经准备执行相同的操作时,一个线程会选择放弃执行,避免不必要的竞争条件和资源浪费。这个模式...
(注意,本资源附带书中源代码可供参考) 多线程与并发处理是程序设计好坏优劣的重要课题,本书通过浅显易懂的文字与实例来介绍Java线程相关的设计模式概念,并且通过实际的Java程序范例和 UML图示来一一解说,书中...
该模式对于管理多线程 Java 应用程序中的状态和并发至关重要。 三、Balking 模式的详细解释及实际示例 实际示例: Balking 设计模式的一个现实世界类比可以在洗衣服务中看到。想象一下自助洗衣店中的洗衣机,只有在...
目录: 漫谈UML Introduction 1 Java语言的线程 Introduction 2 多线程...总结 多线程程序设计的模式语言 附录A 练习问题的解答 附录B Java的内存模型 附录C Java线程的优先级 附录D 线程相关的主要API 附录E 参考文献
Java多线程模式详解 目录: 一、漫谈UML Java语言的线程 多线程的评量标准 二、 1、Single Threaded Execution ———— 能通过这座桥的,只有一个人 2、Immutable ———— 想破坏它也没办法 3、Guarded ...
│ 高并发编程第二阶段29讲、多线程Balking设计模式-上.mp4 │ 高并发编程第二阶段30讲、多线程Balking设计模式-下.mp4 │ 高并发编程第二阶段31讲、多线程Producer and Consumer设计模式.mp4 │ 高并发编程第二...
记录自己学习《图解Java多线程设计模式》这本书的全部过程 本书上传的所有代码都是可以运行的,在此附上本书源码地址: 在此向本书作者和译者表示感谢 运行环境 Eclipse版本:Oxygen.2 Release (4.7.2) JDK版本:jdk...
│ 高并发编程第二阶段29讲、多线程Balking设计模式-上.mp4 │ 高并发编程第二阶段30讲、多线程Balking设计模式-下.mp4 │ 高并发编程第二阶段31讲、多线程Producer and Consumer设计模式.mp4 │ 高并发编程第二...
- **Balking模式**:用于避免不必要的同步操作,如果发现资源状态不需要同步时,则不会进入临界区。 - **读写锁(Read/Write Lock)**:允许多个线程同时读取共享资源,但在写入时只允许一个线程访问。 - **生产...
- 当需要提高多线程环境下的性能时,因为不可变对象可以安全地在多个线程之间共享。 #### 1.4 标记接口(Marker Interface) **使用:** 标记接口是一种特殊的接口类型,它没有任何方法声明。它主要用于表示某种...
值得注意的是,当客户到达但未加入队列,我们称之为“拒载”(balking)。 服务过程是队列理论的另一个核心要素,它涉及到客户服务时间的分布。服务时间可以是均匀的,也可以遵循其他概率分布,如指数分布。服务...
消息可以有不同类型,包括同步消息(sync)、异步消息(async)、超时消息(time-out)以及阻塞消息(Uncommitted / Balking)等。 同步消息通常会导致发送方等待接收方的响应,而异步消息则允许发送方在不等待响应...