这种模式主要是如果对于一个警戒条件成立,那么就可以执行,如果不满足警戒条件,那么只需要返回,不做任何工作。
示例:Data类表示数据,字段content表示内容,changed字段表示是否改变,如果content改变了而没有存储,那么该字段为true,如果content没有改变或者改变了却已经存储了,那么该字段为false。
change方法改变数据,save方法保存数据,仅当changed为true时候才保存。
SaverThread是一个每隔一秒就保存一次数据的线程。
ChangeThread是一个每隔一秒改变数据并且将其保存的线程。
那么应该解决如何:当数据没有改变时,而SaveThread尝试保存数据的问题、以及当数据改变时两个线程先后尝试保存数据的问题。
import java.io.FileWriter; import java.io.IOException; import java.io.Writer; public class Data { private String filename; private String content; private boolean changed;//修改内容后是否保存 public Data(String filename,String content){ this.filename=filename; this.content=content; changed=true; } public synchronized void chang(String s){ content=s; changed=true; } public synchronized void save() throws IOException{ if(!changed) return; doSave(); changed=false; } private void doSave() throws IOException { System.out.println(Thread.currentThread().getName()+" save "+content); Writer writer=new FileWriter(filename); writer.write(content); writer.close(); } }
import java.io.IOException; public class SaverThread extends Thread{ private Data data; public SaverThread(String name,Data data){ super(name); this.data=data; } public void run(){ try{ while(true){ data.save(); Thread.sleep(1000); } }catch(IOException e){ e.printStackTrace(); }catch(InterruptedException e){ e.printStackTrace(); } } }
import java.io.IOException; import java.util.Random; public class ChangerThread extends Thread{ private Data data; private Random random=new Random(); public ChangerThread(String name,Data data){ super(name); this.data=data; } public void run(){ try{ for(int i=0;true;i++){ data.chang("No."+i); Thread.sleep(random.nextInt(1000)); data.save(); } }catch(IOException e){ e.printStackTrace(); }catch(InterruptedException e){ e.printStackTrace(); } } }
public class Test { public static void main(String[] args){ Data data=new Data("data.txt","(empty)"); new ChangerThread("ChangerThread",data).start(); new SaverThread("SaverThread",data).start(); } }
通常有两种方式表示balk的发生,一种是用boolean值,一种是用异常表示,这时会从throw中出异常而不是用return返回。
Guarded Suspension Pattern 中当警戒条件不成立时会一直等待到成立;而Balking Pattern中当警戒条件不成立时会直接balk退出。在这两种模式中有一种折中方案:在条件成立之前等待一段时间。即timeout。
obj.wait(1000);
让线程进入对象obj的等待区域暂停,并且释放obj的锁定。如果一下条件发生线程才会退出等待区域:一、被notify或者notifyAll唤醒;二、对这条线程执行interrupt方法,这是线程重新获得obj的锁定,并抛出InterruptException;三、发生了timeout,即1s钟大概过了,线程又获得obj的锁定。
public class TimeoutException extends Exception{ public TimeoutException(String smg){ super(smg); } }
public class Host { private final long timeout; private boolean ready=false; public Host(long timeout){ this.timeout=timeout; } public synchronized void setExecutable(boolean ready){ this.ready=ready; notifyAll(); } public synchronized void execute() throws TimeoutException, InterruptedException{ long start=System.currentTimeMillis(); //开始计时 while(!ready){ long now=System.currentTimeMillis(); //现在的时间 long rest=timeout-(now-start); if(rest<=0){ throw new TimeoutException("rest="+rest+";timeout="+timeout); //setExecutable(true); } else{ wait(rest);//等待还剩下的时间,如果rest小于0呢(没有机会执行的)? } } doExecute(); } private void doExecute(){ System.out.println(Thread.currentThread().getName()+" doExecute "); } }
public class Main { public static void main(String[] args){ Host host=new Host(10000); System.out.println("Main Begin"); try { host.execute(); } catch (TimeoutException e) { e.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); } } }
运行结果;
Main Begin
TimeoutException: rest=0;timeout=10000
at Host.execute(Host.java:18)
at Main.main(Main.java:7)
synchronized没有timeout,也不能中断。synchronized块中无法设置timeout。
相关推荐
在 Java 开发中,Balking 模式是一种重要的并发设计模式,它可以防止对象在不适当的状态下执行某些代码。本文将详细介绍 Balking 模式的意图、解释、编程示例以及适用场景。同时,还将提供示例代码的下载链接,方便...
Java中的Balking模式是一种多线程设计模式,它主要用于处理多个线程可能对同一资源进行操作的情况,但当发现其他线程已经准备执行相同的操作时,一个线程会选择放弃执行,避免不必要的竞争条件和资源浪费。...
4、Balking ———— 不需要的话,就算了吧 5、Producer-Consumer ———— 我来做,你来用 6、Read-Write Lock ———— 大家想看就看吧,不过看的时候不能写哦 7、Thread-Per-Message ———— 这个工作交给你了 8...
第4章 Balking——不需要的话,就算了吧 第5章 Producer-Consumer——我来做,你来用 第6章 Read-Write Lock——大家想看就看吧,不过看的时候不能写喔 第7章 read-Per-Message——这个工作交给你了 第8章 Worker ...
- **Balking模式**:用于避免不必要的同步操作,如果发现资源状态不需要同步时,则不会进入临界区。 - **读写锁(Read/Write Lock)**:允许多个线程同时读取共享资源,但在写入时只允许一个线程访问。 - **生产...
消息可以有不同类型,包括同步消息(sync)、异步消息(async)、超时消息(time-out)以及阻塞消息(Uncommitted / Balking)等。 同步消息通常会导致发送方等待接收方的响应,而异步消息则允许发送方在不等待响应...
值得注意的是,当客户到达但未加入队列,我们称之为“拒载”(balking)。 服务过程是队列理论的另一个核心要素,它涉及到客户服务时间的分布。服务时间可以是均匀的,也可以遵循其他概率分布,如指数分布。服务...
第1章 Single Threaded Execution——能通过这座桥的,只有一个人 第2章 Immutable——想破坏它也没办法 第3章 Guarded Suspension——要等到我准备好喔 第4章 Balking——不需要的话,就算了吧 第5章 Producer-...
+---balking--------------------------------停止返回模式 +---future---------------------------------等待返回模式 +---builder--------------------------------建造者模式 +---guardedSuspension-------------...
│ 高并发编程第二阶段30讲、多线程Balking设计模式-下.mp4 │ 高并发编程第二阶段31讲、多线程Producer and Consumer设计模式.mp4 │ 高并发编程第二阶段32讲、多线程Count Down设计模式.mp4 │ 高并发编程第二...
│ 高并发编程第二阶段30讲、多线程Balking设计模式-下.mp4 │ 高并发编程第二阶段31讲、多线程Producer and Consumer设计模式.mp4 │ 高并发编程第二阶段32讲、多线程Count Down设计模式.mp4 │ 高并发编程第二...
### 基本设计模型(Fundamental Design Patterns) #### 1.1 授权(Delegation)(When not to use inheritance) **特点:** 在面向对象编程中,继承是一种常用的设计方式,但有时它并不是最合适的解决方案。...