使用Monitor对资源进行保护(二)

简介:   使用Lock语句      首先来看一下出现的问题:   接着我们用Lock来解决这个问题: 创建线程安全类型    上面的类型Resource不是类型安全的,它的内部并没有采取线程安全(Thread-safe)的措施。


  使用Lock语句


     首先来看一下出现的问题:




  接着我们用Lock来解决这个问题:





创建线程安全类型


   上面的类型Resource不是类型安全的,它的内部并没有采取线程安全(Thread-safe)的措施。

   前面的线程同步时由类型的客户端program来实施的,之所以可行,完全是因为program的作者和resource的作者是同一个人。

    因此,最好的办法是将获取锁,释放锁的逻辑放到resource内部来实现。



下面我们用两种方法来改进它:


  方法一:




   方法二:






使用Monitor来协调线程执行顺序


   使用Monitor保证了资源只能同时由一个线程访问,但是没有限制资源现由线程T1访问,还是先由线程T2访问;

   由于Start方法实际执行时间的不确定,因此结果可能是主线程先访问,也可能是worker线程先访问。

   通常,两个线程执行的不同任务,如工作线程获取计算数据,主线程显示数据。那么此时顺序就很重要了。


   我们在此使用wait和pulse方法:


   下面两个分方法都必须位于lock块内,并且两个方法接收的对象与lock接受的对象相同。

 

Wait

Pulse

暂停当前线程并等待信号;

发出信号,接收信号的线程将会执行后续代码。

 







也可以手动设置等待时间:










当有多个线程等待的时候:











目录
相关文章
|
5月前
|
存储 Kubernetes Docker
Kubernetes节点资源耗尽状态的处理
Kubernetes节点资源耗尽状态的处理
|
5月前
|
数据采集 监控 Kubernetes
在k8S中,kubelet监控Worker节点资源是使用什么组件来实现的?
在k8S中,kubelet监控Worker节点资源是使用什么组件来实现的?
|
负载均衡 Kubernetes 算法
k8s--Service 介绍、资源清单
k8s--Service 介绍、资源清单
|
监控 Dubbo Java
监控中心 - Simple Monitor 安装|学习笔记
快速学习监控中心 - Simple Monitor 安装
|
存储 Java 程序员
Monitor
我们Java程序员编码时谈论的最多的两个字就是对象,Java中几乎所有的技术都是围绕对象展开。本文将要讲述的Monitor并不是Java对象,而是在操作系统中关联的“对象”,Monitor是Java重量级锁synchronized实现的关键,因此学习Java单机同步机制就离不开对Monitor的剖析。Monitor从Java层面经常被人们称为监视器锁,而在操作系统层面称为管程。
568 2
Monitor
|
Java 数据库连接 API
try-with-resource:自动地关闭资源
try-with-resource:自动地关闭资源
569 0
|
存储 Kubernetes Docker
Kubernetes节点资源耗尽状态的处理
今天上午一到工位,就收到来自同事的“投诉”:私有云上的Kubernetes cluster中的一个node似乎不工作了,因为专门部署于那个节点上的应用挂掉了,并且长时间没有恢复。这个公司私有云上Kubernetes集群是v1.7.5版本,部署于双节假期之前。
4584 0
|
测试技术
|
监控 内存技术