使用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

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

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

 







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










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











目录
相关文章
|
3月前
|
微服务 Windows
【Azure微服务 Service Fabric 】在SF节点中开启Performance Monitor及设置抓取进程的方式
【Azure微服务 Service Fabric 】在SF节点中开启Performance Monitor及设置抓取进程的方式
|
3月前
|
数据采集 监控 Kubernetes
在k8S中,kubelet监控Worker节点资源是使用什么组件来实现的?
在k8S中,kubelet监控Worker节点资源是使用什么组件来实现的?
|
6月前
[已解决]该主机与 Cloudera Manager Server 失去联系的时间过长。 该主机未与 Host Monitor 建立联系。
[已解决]该主机与 Cloudera Manager Server 失去联系的时间过长。 该主机未与 Host Monitor 建立联系。
179 0
运行项目错误:资源繁忙或者锁定Error: EBUSY:resource busy or locked.lstat
运行项目错误:资源繁忙或者锁定Error: EBUSY:resource busy or locked.lstat
428 0
|
存储 Java 程序员
Monitor
我们Java程序员编码时谈论的最多的两个字就是对象,Java中几乎所有的技术都是围绕对象展开。本文将要讲述的Monitor并不是Java对象,而是在操作系统中关联的“对象”,Monitor是Java重量级锁synchronized实现的关键,因此学习Java单机同步机制就离不开对Monitor的剖析。Monitor从Java层面经常被人们称为监视器锁,而在操作系统层面称为管程。
557 2
Monitor
|
监控 安全 网络协议
[知识小节]Process Monitor介绍(上)
[知识小节]Process Monitor介绍
1198 0
[知识小节]Process Monitor介绍(上)
|
存储 监控 安全
[知识小节]Process Monitor介绍(下)
[知识小节]Process Monitor介绍
1089 0
[知识小节]Process Monitor介绍(下)
|
Prometheus 监控 Cloud Native
|
Oracle 关系型数据库 Linux
oom_kill_process造成数据库挂起并出现found dead shared server
这篇博客是上一篇博客Oracle shutdown immediate遭遇ORA-24324 ORA-24323 ORA-01089的延伸(数据库挂起hang时,才去重启的),其实这是我们海外一工厂的遇到的案例,把内容拆开是因为这个case分开讲述显得主题明确一些。
1303 0