博客
关于我
java并发学习24:固定运行顺序模式
阅读量:313 次
发布时间:2019-03-04

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

1、顺序输出

比如,必须先2后1。

  • wait与notify实现

    static final Object lock = new Object();//表示t2是否运行过static boolean t2runned = false;public static void main(String[] args) {     	Thread t1 = new Thread(() -> {             synchronized (lock) {                 while (!t2runned) {                     try {                         locak.wait();                } catch (InterruptedException e) {                     	e.printStackTrace();                }            }            log.debug("1");        }    },"t1");        Thread t2 = new Thread(() -> {             synchronized (lock) {                 log.debug("2");            t2runned = true;            lock.notify();        }    },"t2");        t1.start();    t2.start();}
  • park与unpark实现

2、交替输出

  • wait与notify实现

    /*输出内容		等待标记		下一个标记a				1				2b				2				3c				3				1*/class WaitNotify {         //打印    public void print(String str,int waitFlag, int nextFlag) {         	synchronized(this) {             	while(flag != waitFlag) {                 	try {                     	this.wait();                } catch (InterruptedExcepton e) {                     	e.printStackTrace();                }            }            System.out.print(str);            flag = nextFlag;            this.notifyAll();        }    }        	//等待标记    private int flag;    //循环次数    private int loopNumber;        public WaitNotify(int flag,int loopNumber) {         	this.flag = flag;        this.loopNumber = loopNumber;    }}
  • await与singal实现

  • park与unpark实现

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

你可能感兴趣的文章
NFS
查看>>
NFS Server及Client配置与挂载详解
查看>>
NFS 服务配置篇
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS安装配置
查看>>
NFS服务器配置-服务启动与停止
查看>>
NFS的安装以及windows/linux挂载linux网络文件系统NFS
查看>>
NFS的常用挂载参数
查看>>
NFS网络文件系统
查看>>
NFS远程目录挂载
查看>>
nft文件传输_利用remoting实现文件传输-.NET教程,远程及网络应用
查看>>
NFV商用可行新华三vBRAS方案实践验证
查看>>
ng build --aot --prod生成文件报错
查看>>
ng 指令的自定义、使用
查看>>
nghttp3使用指南
查看>>
Nginx
查看>>
nginx + etcd 动态负载均衡实践(三)—— 基于nginx-upsync-module实现
查看>>
nginx + etcd 动态负载均衡实践(二)—— 组件安装
查看>>
nginx + etcd 动态负载均衡实践(四)—— 基于confd实现
查看>>