关于Java的Condition接口最佳理解方式
作者:JavaEdge. 发布时间:2021-05-28 19:06:35
Condition就是实现了管程里面的条件变量。
Java 语言内置的管程里只有一个条件变量,而Lock&Condition实现的管程支持多个条件变量。 支持多个条件变量,能让代码可读性更好,实现也更容易。
例如,你看我这里实现一个阻塞队列,就需要两个条件变量:
队列不空 空队列自然没有元素能出队队列不满
队列已满,当然也不可有元素再入队
Lock和Condition实现的管程,线程等待和通知需要调用await()、signal()、signalAll(),它们的语义和wait()、notify()、notifyAll()相同。
Lock&Condition实现的管程里只能使用await()、signal()、signalAll()
synchronized实现的管程才能使用wait()、notify()、notifyAll()
如果在Lock&Condition实现的管程里调用wait()、notify()、notifyAll(),你距离离职就更近一步了。
Thread.sleep() V.S Condition.await()
Object.wait()和Condition.await()的原理是基本一致的,不同在于Condition.await()底层是调用LockSupport.park()实现阻塞当前线程。它在阻塞当前线程前,其实还做了:
把当前线程添加到条件队列
完全释放锁,即让state=0,然后才调用
LockSupport.park()
阻塞当前线程
JDK的Lock和Condition不过就是管程的一种实现,一般如何使用呢?
什么是同步与异步?
同步 调用方需要等待结果
异步 不需要等待结果
代码里如何实现异步?
调用方创建一个子线程,在子线程中执行方法调用,即异步调用
方法实现时,创建一个新的线程执行主要逻辑,主线程直接return,即异步方法。
异步场景挺多,比如TCP协议本身是异步的,日常的RPC调用,在TCP协议层面,发送完RPC请求后,线程不会等待RPC响应结果。
是不是好奇了,明明日常使用的RPC调用都是同步的呀?这到底是同步还是异步?
这肯定有人帮忙实现了异步转同步。比如RPC框架Dubbo,具体它是怎么做到的呢?
对于下面一个简单的RPC调用,默认情况下sayHello()是个同步方法,即执行service.sayHello(“dubbo”)时,线程会停下来等结果。
DemoService service = 初始化部分省略
String message = service.sayHello("dubbo");
System.out.println(message);
若此时dump调用线程的调用栈
发现调用线程阻塞了,线程状态是TIMED_WAITING。本来发送请求是异步的,但是调用线程却阻塞了,说明Dubbo帮我们做了异步转同步的事情。通过调用栈看到线程是阻塞在DefaultFuture.get()
,所以Dubbo异步转同步的功能应该是通过DefaultFuture实现。
DefaultFuture.get()之前发生了什么呢:
我们的期望:
RPC返回结果前,阻塞调用线程,让调用线程等待
RPC返回结果后,唤醒调用线程,让调用线程重新执行
这就是经典的等待-通知机制,即管程的实现方案。
看看Dubbo是怎么实现的。
来源:https://javaedge.blog.csdn.net/article/details/115953976


猜你喜欢
- 在application.properties中配置了static的默认路径我的static目录结构是这样的index.html中这样引用c
- > 此文主要通过WinForm来制作一个休息提醒闹钟,通过设置时间间隔进行提醒,避免沉浸式的投入到工作或者学习当中,战斗的同时也要照顾
- Mybatis 有两种实现方式其一:通过xml配置文件实现其二:面向接口编程的实现
- 拼图小游戏,学习阶段。很多不足,改进了一下演示图片:J_Puzzle.javaimport java.awt.BorderLayout;im
- 本文实例讲述了C#转换日期类型的方法。分享给大家供大家参考。具体分析如下:如:将日期1999-5-31 11:20转换成 /Date(928
- 刚开始学习C#的时候,就听说CLR对于String类有一种特别的内存管理机制:有时候,明明声明了两个String类的对象,但是他们偏偏却指向
- 刚学习c#的朋友要自己手动编译c#代码加深记忆,现在总结下如果手动编译!1、先找到系统的.net 环境在一般在 C:\Window
- 本文实例为大家分享了Java解码H264格式视频流中的图片,供大家参考,具体内容如下引入依赖<dependency>
- 简介项目需要...直接展示效果吧:原理使用UGUI提供的ScrollRect和ScrollBar组件实现基本滑动以及自己控制每次移动一页来达
- 目录通过Resource接口手动加载通过@Value自动转换通过ResourceLoader加载使用ResourceUtils加载资源读取资
- 本文实例为大家分享了Android仿Iphone屏幕底部弹出效果的具体代码,供大家参考,具体内容如下main.xml如下: <?xml
- Java针对多线程下的数值安全计数器设计了一些类,这些类叫做原子类,其中一部分如下:java.util.concurrent.atomic.
- 本文主要给大家介绍的是关于Android实现微信雷达扫描效果的相关内容,分享出来供大家参考学习,下面来看看详细的介绍:废话不多说 先上图(用
- 一、简介WorkManager 用于处理 Android 后台任务。我们只需要设置好任务内容、何时执行,剩下的工作就可以完全交给系统处理。它
- 效果图如下:类注释:方法注释:idea不会默认帮我们设置,所以需要手动设置。1:IDEA中在创建类时会自动给添加注释打开idea,操作Fil
- Android获取系统内核版本的方法 &nbs
- 本篇主要描述“发送邮箱验证码、session校验”相关前(html\js)后(java)台代码,业务逻辑示例,闲话少诉,直接上代码。1、引入
- 注解说明使用注解: @PostConstruct效果:在Bean初始化之后(构造方法和@Autowired之后)执行指定操作。经常用在将构造
- 1、三元运算符:class Program {
- 本文实例为大家分享了java实现随机数生成器的具体代码,供大家参考,具体内容如下自己编的随机数生成器,比较简陋,功能也单一,当作练手。App