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

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

 

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

    /*** 用于线程之间等待并传递信息 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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

高并发环境中保持幂等性

在高并发环境中保持幂等性是一项重要的挑战。幂等性指的是无论操作执行多少次,其效果都是相同的。确保操作的幂等性可以避免重复执行带来的副作用。以下是一些保持幂等性的常用方法: 唯一标识符: 请求唯一标识:在每次请求中引入唯一标识符(如 UUID 或者生成的唯一 ID),在处理请求时,系统可以检查这个标识符是否已经处理过,如果是,则忽略重复请求。幂等键(Idempotency Key):客户端在每次

二分最大匹配总结

HDU 2444  黑白染色 ,二分图判定 const int maxn = 208 ;vector<int> g[maxn] ;int n ;bool vis[maxn] ;int match[maxn] ;;int color[maxn] ;int setcolor(int u , int c){color[u] = c ;for(vector<int>::iter

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000