博客
关于我
四. 精确通知顺序访问
阅读量:278 次
发布时间:2019-03-01

本文共 2542 字,大约阅读时间需要 8 分钟。

多线程之间按顺序调用,实现A->B->C三个线程启动,要求如下:

  AA打印5次,BB打印10次,CC打印15次 接着AA打印5次,BB打印10次,CC打印15次

  1. 高聚低合前提下,线程操作资源类
  2. 判断/干活/通知
  3. 多线程交互中,必须防止多线程的虚假唤醒,也即(判断只能用while,不能用if)
  4. 标志位
//三个操作方法的版本import java.util.concurrent.locks.Condition;import java.util.concurrent.locks.Lock;import java.util.concurrent.locks.ReentrantLock;class ShareResource{       private int number = 1;  //1:A, 2:B, 3:C    private Lock lock = new ReentrantLock();    private Condition condition1 = lock.newCondition();    private Condition condition2 = lock.newCondition();    private Condition condition3 = lock.newCondition();    public void print5(){           lock.lock();        try{               while(number!=1){                   condition1.await();            }            for (int i = 0; i < 5; i++) {                   System.out.println(Thread.currentThread().getName()+"\tA");            }            number = 2;            condition2.signal();        }catch(Exception e){               e.printStackTrace();        }finally{               lock.unlock();        }    }    public void print10(){           lock.lock();        try{               while(number!=2){                   condition2.await();            }            for (int i = 0; i < 10; i++) {                   System.out.println(Thread.currentThread().getName()+"\tB");            }            number = 3;            condition3.signal();        }catch(Exception e){               e.printStackTrace();        }finally{               lock.unlock();        }    }    public void print15(){           lock.lock();        try{               while(number!=3){                   condition3.await();            }            for (int i = 0; i < 15; i++) {                   System.out.println(Thread.currentThread().getName()+"\tC");            }            number = 1;            condition1.signal();        }catch(Exception e){               e.printStackTrace();        }finally{               lock.unlock();        }    }}public class ThreadOrderAccess {       public static void main(String[] args) {           ShareResource shareResource = new ShareResource();        new Thread(()->{               for (int i = 0; i < 10; i++) {                   shareResource.print5();            }        },"thread1").start();        new Thread(()->{               for (int i = 0; i < 10; i++) {                   shareResource.print10();            }        },"thread2").start();        new Thread(()->{               for (int i = 0; i < 10; i++) {                   shareResource.print15();            }        },"thread3").start();    }}

转载地址:http://ajco.baihongyu.com/

你可能感兴趣的文章
Netty工作笔记0061---Netty心跳处理器编写
查看>>
Netty工作笔记0063---WebSocket长连接开发2
查看>>
Netty工作笔记0065---WebSocket长连接开发4
查看>>
Netty工作笔记0066---Netty核心模块内容梳理
查看>>
Netty工作笔记0068---Protobuf机制简述
查看>>
Netty工作笔记0070---Protobuf使用案例Codec使用
查看>>
Netty工作笔记0071---Protobuf传输多种类型
查看>>
Netty工作笔记0072---Protobuf内容小结
查看>>
Netty工作笔记0073---Neety的出站和入站机制
查看>>
Netty工作笔记0074---handler链调用机制实例1
查看>>
Netty工作笔记0075---handler链调用机制实例1
查看>>
Netty工作笔记0076---handler链调用机制实例3
查看>>
Netty工作笔记0077---handler链调用机制实例4
查看>>
Netty工作笔记0078---Netty其他常用编解码器
查看>>
Netty工作笔记0079---Log4j整合到Netty
查看>>
Netty工作笔记0080---编解码器和处理器链梳理
查看>>
Netty工作笔记0081---编解码器和处理器链梳理
查看>>
Netty工作笔记0082---TCP粘包拆包实例演示
查看>>
Netty工作笔记0083---通过自定义协议解决粘包拆包问题1
查看>>
Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
查看>>