当现在不适合这个操作,或是没有必要进行这个操作时就直接放弃这个操作而回去。这个就是Balking模式例如王某在餐厅吃饭,当王某需要点餐时喊服务员需要点餐。当服务员A和B都注意到了王某点餐的示意,这时服务员B看到服务员A已经去响应了王某的点餐请求,所以服务员B就不会再过去响应王某的点餐请求。
程序示例:程序的需求是模拟一个自动保存的功能。自动保存是为了预防计算机忽然断电或则软件突然出错的危险,定期将数据保存在文件里的功能。
1、Data类:表示是否修改,及修改函数的类2、SaveThread类:定期保存3、ChangeThread:修改数据,保存文件4、Main:模拟数据
view plainprint?
package org.zhy.demo04;
import java.io.FileWriter;import java.io.IOException;import java.io.Writer;/** * 表示是否修改,及修改函数的类* @author zhengyi * */ public class Data {
private final String fileName; //文件名称private String content; //修改内容private boolean changed; //是否可以修改
//构造函数public Data(String fileName,String content){ this.fileName=fileName;this.content=content;}
/** * 新的修改内容 如果有新的需要保存的数据,changed的属性修改为true * 注:这个方法是用synchronized修饰的* 为了保护content与changed属性用* synchronized修饰后就只能同时有* 1个线程访问也就防止了多线程造成的脏数据* @param newContent */ public synchronized void change(String newContent){ content=newContent;changed=true;}
/** * 保存*/ public synchronized void save(){ if(!changed){ //当changed值为false时直接return出去return ;}else{ doSave();//调用保存方法changed=false; //保存后changed的值修改为false } /** * 具体的修改方法,模拟写到文本中。
*/ private void doSave(){ System.out.println("线程名称:"+Thread.currentThread()。getName()+",最新需要保存的值="+content);try { Writer writer=new FileWriter(fileName);writer.write(content);writer.close();} catch (IOException e) { e.printStackTrace();}
}
}
view plainprint?
package org.zhy.demo04;
/** * 定期保存的类* @author zhengyi * */ public class SaveThread extends Thread{
private Data data;public SaveThread(String name,Data data){ super(name);//线程名称this.data=data;}
public void run(){ try { while(true){ data.save(); //模拟保存方法Thread.sleep(1000); //休息1秒} } catch (Exception e) { e.printStackTrace();}
view plainprint?
package org.zhy.demo04;
import java.util.Random;/** * 修改数据,保存文件的类* @author zhengyi * */ public class ChangeThread extends Thread{
private Data data;private Random random=new Random();public ChangeThread(String name,Data data){ super(name);//线程名称this.data=data;} public void run(){ try { for(int i=0;true;i++){ data.change("No:"+i); //模拟的数据Thread.sleep(random.nextInt(1000)); //模拟去做别的事情data.save(); //明确的要求要保存} } catch (Exception e) { e.printStackTrace();}
view plainprint?
package org.zhy.demo04;
public class Main {
public static void main(String[] args) { Data data=new Data("data.txt", "我是默认内容"); //文件的名称及文件的默认内容new ChangeThread("ChangeThread", data)。start(); //手动保存new SaveThread("SaveThread", data)。start(); //自动保存}
运行结果:
什么时候使用Balking模式?
1、不需要刻意去执行的时候2、不想等待警戒条件时3、警戒条件只有一次成立时
分享到:
相关推荐
(注意,本资源附带书中源代码可供参考) 多线程与并发处理是程序设计好坏优劣的重要课题,本书通过浅显易懂的文字与实例来介绍Java线程相关的设计模式概念,并且通过实际的Java程序范例和 UML图示来一一解说,书中...
Java中的Balking模式是一种多线程设计模式,它主要用于处理多个线程可能对同一资源进行操作的情况,但当发现其他线程已经准备执行相同的操作时,一个线程会选择放弃执行,避免不必要的竞争条件和资源浪费。这个模式...
该模式对于管理多线程 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 │ 高并发编程第二...
以上内容涵盖了JSP的基本概念、Servlet的工作原理、多线程同步机制、Java中的访问权限控制、数据库操作的基本流程、正则表达式的应用以及文件读写的相关知识。这些知识点对于Java开发者来说非常重要,掌握它们能够...
- 当需要提高多线程环境下的性能时,因为不可变对象可以安全地在多个线程之间共享。 #### 1.4 标记接口(Marker Interface) **使用:** 标记接口是一种特殊的接口类型,它没有任何方法声明。它主要用于表示某种...