JAVA多线程模式-Balking

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA多线程模式-Balking相关的知识,希望对你有一定的参考价值。

  • Balking

    • 多线程共享一个资源,该资源发现无法提供服务则拒绝接受请求,请求将失败而不是继续等待资源。

    • 适用环境

      • 对共享资源的请求是可被拒绝、不需要等待的。

    • 样例

      • 秒杀。

      • 只有一定数量的商品,超出数量的请求将被舍弃。

    • 请求类


    • package Balking;
      
      public class Request {
      
      	private String orderId=null;
      	public Request(String orderId) {
      		this.orderId=orderId;
      	}
      	public String getOrderId(){
      		return this.orderId;
      	}
      }

    • 仓库类


    • package Balking;
      
      import java.util.LinkedList;
      
      //guarded object
      public class Inventory {
      	private final LinkedList<Request> items=new LinkedList<Request>();
      	private final int size;
      	
      	public Inventory(int size){
      		this.size=size;
      	}
      	//guarded method
      	public synchronized int put(Request req){
      		int ret=0;
      		if(items.size()<size){
      			items.add(req);
      			ret=1;
      		}
      		return ret;
      	}
      		
      	public synchronized Request get(){
      		Request ret=null;		
      		ret=items.poll();
      		return ret;
      	}
      }

    • 客户端


    • package Balking;
      
      import java.util.UUID;
      
      public class Client implements Runnable{
      
      	private Inventory inventory=null;
      	private final String myName;
      	
      	public Client(String myName,Inventory inventory){
      		this.inventory=inventory;
      		this.myName=myName;
      	}
      	@Override
      	public void run() {
      		int ret=1;
      		while(ret==1){
      			String orderId=UUID.randomUUID().toString();
      			Request req=new Request(orderId);
      			ret=this.inventory.put(req);
      			if(ret==1){
      				System.out.println(this.myName+" 订单:"+req.getOrderId()+"已提交!");
      			}else{
      				System.out.println(this.myName+" 商品已售罄!请求被拒绝!关闭请求渠道!");
      			}
      		}		
      	}
      
      }

    • 服务器端


    • 				package Balking;
      
      public class Server implements Runnable{
      
      	private Inventory inventory=null;
      	
      	public Server(Inventory inventory){
      		this.inventory=inventory;
      	}
      	@Override
      	public void run() {
      		try {
      			Thread.sleep(1000);
      		} catch (InterruptedException e) {
      			e.printStackTrace();
      		}
      		int flag=0;
      		while(flag==0){
      			Request req=this.inventory.get();
      			if(req!=null){
      				System.out.println("订单处理:"+req.getOrderId());
      			}else{
      				System.out.println("全部订单已处理完毕!");
      				flag=-1;
      			}
      		}
      		
      	}
      
      }

    • 测试类


    • 				package Balking;
      
      public class Test {
      	public static void main(String[] args) {
      		Inventory inv=new Inventory(10);
      		Client c1=new Client("c1",inv);
      		Client c2=new Client("c2",inv);
      		Client c3=new Client("c3",inv);
      		Client c4=new Client("c4",inv);
      		Client c5=new Client("c5",inv);
      		
      		Server s=new Server(inv);
      		
      		Thread ct1=new Thread(c1);
      		Thread ct2=new Thread(c2);
      		Thread ct3=new Thread(c3);
      		Thread ct4=new Thread(c4);
      		Thread ct5=new Thread(c5);
      		Thread st=new Thread(s);
      		
      		ct1.start();
      		ct2.start();
      		ct3.start();
      		ct4.start();
      		ct5.start();
      		st.start();
      		
      		try {
      			ct1.join();
      			ct2.join();
      			ct3.join();
      			ct4.join();
      			ct5.join();
      			st.join();
      		} catch (InterruptedException e) {
      			e.printStackTrace();
      		}
      		
      		System.out.println("秒杀结束!");
      	}
      }

本文出自 “JAVA技术栈笔记” 博客,请务必保留此出处http://stroll.blog.51cto.com/11038467/1856629

以上是关于JAVA多线程模式-Balking的主要内容,如果未能解决你的问题,请参考以下文章

Day851.Balking模式 -Java 性能调优实战

JUC并发编程 多线程设计模式 -- 同步模式之 Balking

多线程系列之五:Balking 模式

共享模型之内存

JUC并发编程 原理之 volatile -- 保证可见性 & 保证有序性 & 习题 balking模式

java多线程其实本节和多线程无关,简单的模板设计模式