并发编程之两阶段终止模式 保护性暂停 顺序与交替模式 总结

本文主要是介绍并发编程之两阶段终止模式 保护性暂停 顺序与交替模式 总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

 保护性暂停可以解耦添加一个消息队列 升级为生产者消费者模式

    /*** 用于线程之间等待并传递信息 join方法基于此实现*/static class GuardedObject {//标识private int id;//结果private Object response;public GuardedObject(){}public GuardedObject(int id){this.id = id; }public int getId(){return id;}//超时时间timeoutpublic Object get(long timeout){synchronized (this){//开始时间long begin = System.currentTimeMillis();//经过时间long passedTime = 0;while(response == null){long waitTime = timeout - passedTime;if(timeout - passedTime < 0){break;}try {//设置等待超时this.wait(waitTime);} catch (InterruptedException e) {e.printStackTrace();}passedTime = System.currentTimeMillis() - begin;}return response;}}public void complete(Object response){synchronized (this){this.response = response;//获取到结果唤醒等待对列中所有的值this.notifyAll();}}}

 

/*** 两阶段终止*/
@Slf4j(topic = "designDemo")
class DesignDemo {private Thread monitor;public void start(){monitor = new Thread(() -> {while (true){Thread thread = Thread.currentThread();if(thread.isInterrupted()){log.debug("线程退出前执行。。。");break;}try {TimeUnit.SECONDS.sleep(1);log.debug("线程监控中。。。");} catch (InterruptedException e) {e.printStackTrace();//出现异常重新打断 异常会将打断标记重置为假thread.interrupt();}}});monitor.start();}public void stop(){monitor.interrupt();}
}

 同步顺序模式

@Slf4j(topic = "c.test04")
public class Test04 {//锁static final Object lock = new Object();//t2运行标记static boolean t2runned = false;//wait notify 实现同步顺序执行public static void waitMethod() {Thread t1 = new Thread(()->{synchronized (lock) {//while 防止虚假唤醒while(!t2runned){try{//等待释放锁 t2就能拿到锁lock.wait();}catch (InterruptedException e){e.printStackTrace();}}log.info("1");}},"t1");Thread t2 = new Thread(()->{synchronized (lock){log.info("2");t2runned = true;lock.notify();}},"t2");t1.start();t2.start();}//park 实现public static void parkMethod() {Thread t1 = new Thread(()->{LockSupport.park();log.info("1");},"t1");Thread t2 = new Thread(()->{log.info("2");LockSupport.unpark(t1);},"t2");t1.start();t2.start();}}

 交替输出模式

//打印方法 每个线程实现传入打印数据str 自己的等待标记 下一个调用的线程等待标记
public void print(String str, int waitFlag, int nextFlag){for (int i = 0; i < loopNumber; i++) {synchronized (this){while(flag != waitFlag){try{this.wait();}catch (InterruptedException e){e.printStackTrace();}}}}System.out.println(str);flag = nextFlag;this.notifyAll();}private int flag;private int loopNumber;//构造方法初始化第一个线程标记和循环次数public Test05(int flag, int loopNumber){this.flag = flag;this.loopNumber = loopNumber;}

这篇关于并发编程之两阶段终止模式 保护性暂停 顺序与交替模式 总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/774592

相关文章

一文带你搞懂Redis Stream的6种消息处理模式

《一文带你搞懂RedisStream的6种消息处理模式》Redis5.0版本引入的Stream数据类型,为Redis生态带来了强大而灵活的消息队列功能,本文将为大家详细介绍RedisStream的6... 目录1. 简单消费模式(Simple Consumption)基本概念核心命令实现示例使用场景优缺点2

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringBoot中配置文件的加载顺序解读

《SpringBoot中配置文件的加载顺序解读》:本文主要介绍SpringBoot中配置文件的加载顺序,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot配置文件的加载顺序1、命令⾏参数2、Java系统属性3、操作系统环境变量5、项目【外部】的ap

Nginx location匹配模式与规则详解

《Nginxlocation匹配模式与规则详解》:本文主要介绍Nginxlocation匹配模式与规则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、环境二、匹配模式1. 精准模式2. 前缀模式(不继续匹配正则)3. 前缀模式(继续匹配正则)4. 正则模式(大

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.