黑马程序员_银行业务系统(2)

------- android培训java培训、期待与您交流! ----------

  • ServiceWindow类定义一个start方法,内部启动一个线程,
  • 根据服务窗口的类别分别循环调用三个不同的方法。
  • 定义三个方法分别对三种客户进行服务,为了观察运行效果,
  • 应详细打印出其中的细节信息。

import java.util.Random; 
import java.util.concurrent.Executors; 
import java.util.logging.Logger; 
 
/** 
 * 没有把VIP窗口和快速窗口做成子类,是因为实际业务中的普通窗口可以随时
 * 被设置为VIP窗口和快速窗口。 
 * */ 
public class ServiceWindow{ 
    private static Logger logger = Logger.getLogger("cn.itcast.bankqueue"); 
    private CustomerTypetype =CustomerType.COMMON; 
    private int number = 1; 
 
    public CustomerTypegetType() { 
        return type; 
    } 
 
    public void setType(CustomerType type) { 
        this.type = type; 
    } 
     
    public void setNumber(int number){ 
        this.number = number; 
    } 
     
    public void start(){ 
        Executors.newSingleThreadExecutor().execute( 
                new Runnable(){ 
                    public void run(){ 
                        //下面这种写法的运行效率低,最好是把while放在case下面 
                        while(true){ 
                            switch(type){ 
                                caseCOMMON: 
                                   commonService(); 
                                    break; 
                                caseEXPRESS: 
                                   expressService(); 
                                    break; 
                                caseVIP: 
                                   vipService(); 
                                    break; 
                            } 
                        } 
                    } 
                } 
        ); 
    } 
     
    private void commonService(){ 
        String windowName = "第" +number +"号" +type +"窗口";         
        System.out.println(windowName +"开始获取普通任务!"); 
        Integer serviceNumber = NumberMachine.getInstance()
                                            .getCommonManager().fetchNumber();        
        if(serviceNumber !=null ){ 
            System.out.println(windowName +"开始为第" 
                                            + serviceNumber +"号普通客户服务");         
            int maxRandom =Constants.MAX_SERVICE_TIME-Constants
                                            .MIN_SERVICE_TIME; 
            int serviceTime =new Random().nextInt(maxRandom)+1 +Constants
                                            .MIN_SERVICE_TIME; 
     
            try { 
                Thread.sleep(serviceTime); 
            } catch (InterruptedException e){ 
                e.printStackTrace(); 
            }    
            System.out.println(windowName +"完成为第" + serviceNumber 
                        +"号普通客户服务,总共耗时" + serviceTime/1000 +"秒");        
        }else{ 
            System.out.println(windowName +"没有取到普通任务,正在空闲一秒");      
            try { 
                Thread.sleep(1000); 
            } catch (InterruptedException e){ 
                e.printStackTrace(); 
            }                
        } 
    } 
     
    private void expressService(){ 
        Integer serviceNumber = NumberMachine.getInstance()
                                            .getExpressManager().fetchNumber(); 
        String windowName = "第" +number +"号" +type +"窗口";    
        System.out.println(windowName +"开始获取快速任务!");        
        if(serviceNumber !=null){ 
            System.out.println(windowName +"开始为第" + serviceNumber 
                                                            +"号快速客户服务");             
            int serviceTime =Constants.MIN_SERVICE_TIME; 
            try { 
                Thread.sleep(serviceTime); 
            } catch (InterruptedException e){ 
                e.printStackTrace(); 
            }        
            System.out.println(windowName +"完成为第" + serviceNumber 
            +"号快速客户服务,总共耗时" + serviceTime/1000 +"秒");       
        }else{ 
            System.out.println(windowName +"没有取到快速任务!");                
            commonService(); 
        } 
    } 
     
    private void vipService(){ 
 
        Integer serviceNumber = NumberMachine.getInstance()
                                    .getVipManager().fetchNumber(); 
        String windowName = "第" +number +"号" +type +"窗口";    
        System.out.println(windowName +"开始获取VIP任务!");           
        if(serviceNumber !=null){ 
            System.out.println(windowName +"开始为第" 
                                    + serviceNumber +"号VIP客户服务");            
            int maxRandom =Constants.MAX_SERVICE_TIME-Constants.MIN_SERVICE_TIME; 
            int serviceTime =new Random().nextInt(maxRandom)+1 
                                                    +Constants.MIN_SERVICE_TIME; 
            try { 
                Thread.sleep(serviceTime); 
            } catch (InterruptedException e){ 
                e.printStackTrace(); 
            }        
            System.out.println(windowName +"完成为第" + serviceNumber 
                        +"号VIP客户服务,总共耗时" + serviceTime/1000 +"秒");      
        }else{ 
            System.out.println(windowName +"没有取到VIP任务!");               
            commonService(); 
        }    
    } 
} 
  • MainClass类:用for循环创建出4个普通窗口,再创建出1个快速窗口和
  • 一个VIP窗口。接着再创建三个定时器,分别定时去创建新的普通客户号码、
  • 新的快速客户号码、新的VIP客户号码。
  • Constants类:定义三个常量:MAX_SERVICE_TIME、MIN_SERVICE_TIME、
  • COMMON_CUSTOMER_INTERVAL_TIME
import java.util.concurrent.Executors; 
import java.util.concurrent.TimeUnit; 
import java.util.logging.Logger; 
 
public class MainClass { 
     
    private static Logger logger = Logger.getLogger("cn.itcast.bankqueue"); 
     
 
    public static void main(String[] args) { 
        //产生4个普通窗口 
        for(int i=1;i<5;i++){ 
            ServiceWindow window =  newServiceWindow(); 
            window.setNumber(i); 
            window.start(); 
        } 
     
        //产生1个快速窗口 
        ServiceWindow expressWindow=  newServiceWindow(); 
        expressWindow.setType(CustomerType.EXPRESS); 
        expressWindow.start(); 
         
        //产生1个VIP窗口      
        ServiceWindow vipWindow =  newServiceWindow(); 
        vipWindow.setType(CustomerType.VIP); 
        vipWindow.start();       
         
        //普通客户拿号 
        Executors.newScheduledThreadPool(1).scheduleAtFixedRate( 
                new Runnable(){ 
                    public void run(){ 
                        Integer serviceNumber =NumberMachine.getInstance()
                        .getCommonManager().generateNewNumber(); 
                        /** 
                         * 采用logger方式,无法看到直观的运行效果,因为
                         * logger.log方法内部并不是直接把内容打印出出来, 
                         * 而是交给内部的一个线程去处理,所以,打印出来的结果在
                         * 时间顺序上看起来很混乱。 
                         */ 
                        //logger.info("第"+ serviceNumber 
                                                + "号普通客户正在等待服务!"); 
                        System.out.println("第" + serviceNumber 
                                                 +"号普通客户正在等待服务!");                        
                    } 
                }, 
                0, 
                Constants.COMMON_CUSTOMER_INTERVAL_TIME,  
                TimeUnit.SECONDS); 
         
        //快速客户拿号 
        Executors.newScheduledThreadPool(1).scheduleAtFixedRate( 
                new Runnable(){ 
                    public void run(){ 
                        Integer serviceNumber =NumberMachine.getInstance()
                        .getExpressManager().generateNewNumber(); 
                        System.out.println("第" + serviceNumber 
                        +"号快速客户正在等待服务!"); 
                    } 
                }, 
                0, 
                Constants.COMMON_CUSTOMER_INTERVAL_TIME* 2,  
                TimeUnit.SECONDS); 
         
        //VIP客户拿号 
        Executors.newScheduledThreadPool(1).scheduleAtFixedRate( 
                new Runnable(){ 
                    public void run(){ 
                        Integer serviceNumber =NumberMachine.getInstance()
                                        .getVipManager().generateNewNumber(); 
                        System.out.println("第" + serviceNumber 
                                                    +"号VIP客户正在等待服务!"); 
                    } 
                }, 
                0, 
                Constants.COMMON_CUSTOMER_INTERVAL_TIME* 6,  
                TimeUnit.SECONDS); 
    } 
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值