一、notify()

作用:唤醒一个正在等待该线程的锁的线程

PS : 唤醒的线程不会立即执行,它会与其他线程一起,争夺资源

/**
* Object类的notify()和notifyAll()方法详解
*/
public class MyNotify { // 在多线程间共享的对象上使用wait
private String[] shareObj = {"true"}; public static void main(String[] args) {
MyNotify test = new MyNotify();
//创建3个等待线程
ThreadWait threadWait1 = test.new ThreadWait("线程1");
ThreadWait threadWait2 = test.new ThreadWait("线程2");
ThreadWait threadWait3 = test.new ThreadWait("线程3");
//创建一个解放线程对象,用于通知等待线程运行
ThreadNotify threadNotify = test.new ThreadNotify("释放线程"); //等待线程启动,在释放线程把锁释放之后,争夺运行的机会
threadWait1.start();
threadWait2.start();
threadWait3.start(); //释放线程启动,sleep3秒后释放线程
threadNotify.start();
} /**
* 线程等待类
*/
class ThreadWait extends Thread { //调用父类构造方法设置线程名称
public ThreadWait(String name) {
super(name);
} public void run() {
synchronized (shareObj) {
while ("true".equals(shareObj[0])) {
System.out.println("线程" + this.getName() + "开始等待");
long startTime = System.currentTimeMillis();
try {
shareObj.wait();//无尽等待,直至notify()或者notifyAll()
} catch (InterruptedException e) {
e.printStackTrace();
}
long endTime = System.currentTimeMillis();
System.out.println("线程" + this.getName()
+ "等待时间为:" + (endTime - startTime));
}
}
System.out.println("线程" + getName() + "等待结束");
}
} /**
* 线程释放类
*/
class ThreadNotify extends Thread { //调用父类构造方法设置线程名称
public ThreadNotify(String name) {
super(name);
} public void run() {
try {
// 给等待线程等待时间
sleep(3000);//此时sleep方法会获取对象锁,其他线程处于等待并获取锁的状态
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (shareObj) {
System.out.println(this.getName() + "开始准备通知");
shareObj[0] = "false";
shareObj.notify();//解放一个正在等待的线程(随机)
// shareObj.notifyAll();//解放所有等待的线程
System.out.println(this.getName() + "通知结束");
}
System.out.println(this.getName() + "运行结束");
}
}
}

详见这里~

二、notifyAll()

作用:唤醒所有正在等待该线程的锁的线程

PS:并不一定会按线程优先级来执行

三、wait()

作用:导致当前的线程进入无尽等待,直到其他线程调用此对象的notify( ) 方法或 notifyAll( ) 方法

四、wait(long timeout)

作用:导致当前的线程等待,直到其他线程调用此对象的notify() 方法或 notifyAll() 方法,或者指定的时间过完。

五、wait(long timeout, int nanos)

作用:类似于wait(long timeout)方法,更精准,附加时间在毫微秒范围0-999999。

六、常见异常

  • IllegalArgumentException -- 如果超时的值是负的或毫微秒的值不在0-999999范围内。
  • IllegalMonitorStateException -- 如果当前线程不是对象监视器的拥有者。
  • InterruptedException -- 如果另一个线程中断了当前线程。当这种异常被抛出当前线程的中断状态被清除。

并发编程(六)Object类中线程相关的方法详解的更多相关文章

  1. PHP 中 16 个魔术方法详解

    PHP 中 16 个魔术方法详解   前言 PHP中把以两个下划线__开头的方法称为魔术方法(Magic methods),这些方法在PHP中充当了举足轻重的作用. 魔术方法包括: __constru ...

  2. moviepy音视频剪辑:视频剪辑基类VideoClip的属性及方法详解

    ☞ ░ 前往老猿Python博文目录 ░ 一.概述 在<moviepy音视频剪辑:moviepy中的剪辑基类Clip详解>和<moviepy音视频剪辑:moviepy中的剪辑基类Cl ...

  3. “全栈2019”Java多线程第五章:线程睡眠sleep()方法详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  4. php_DWZ-JUI中碰到的问题解决方法详解(thinkphp+dwz)

    原文:php_DWZ-JUI中碰到的问题解决方法详解(thinkphp+dwz) 折腾了两天,dwz删除后,数据不能自动刷新,解决方案,直接看图  . 1. 删除.修改状态后无法刷新记录: 在dwz. ...

  5. “全栈2019”Java多线程第七章:等待线程死亡join()方法详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  6. python中requests库使用方法详解

    目录 python中requests库使用方法详解 官方文档 什么是Requests 安装Requests库 基本的GET请求 带参数的GET请求 解析json 添加headers 基本POST请求 ...

  7. Object类中的五种方法

    clone() Object类源码:protected native Object clone() throws CloneNotSupportedException; 这里有个问题:为什么Sun公司 ...

  8. Java中 hashCode()方法详解

    先来看下Object源码里hashcode方法: /**     * Returns a hash code value for the object. This method is      * s ...

  9. Java中hashCode与equal方法详解

    转载自http://blog.csdn.net/jiangwei0910410003/article/details/22739953 Java中的equals方法和hashCode方法是Object ...

随机推荐

  1. 第一篇Scrum冲刺博客

    目录 一.Alpha 阶段认领的任务 二.明日成员的任务安排 三.整个项目预期的任务量 四.敏捷开发前的感想 五.团队期望 一.Alpha 阶段认领的任务 陈起廷 任务 预计时间 日记天气.心情选择 ...

  2. 一次完整的JVM堆外内存泄漏故障排查记录

    前言 记录一次线上JVM堆外内存泄漏问题的排查过程与思路,其中夹带一些JVM内存分配机制以及常用的JVM问题排查指令和工具分享,希望对大家有所帮助. 在整个排查过程中,我也走了不少弯路,但是在文章中我 ...

  3. Istio的流量管理(实操三)

    Istio的流量管理(实操三) 涵盖官方文档Traffic Management章节中的egress部分.其中有一小部分问题(已在下文标注)待官方解决. 目录 Istio的流量管理(实操三) 访问外部 ...

  4. 面试:为了进阿里,死磕了ThreadLocal内存泄露原因

    前言 在分析ThreadLocal导致的内存泄露前,需要普及了解一下内存泄露.强引用与弱引用以及GC回收机制,这样才能更好的分析为什么ThreadLocal会导致内存泄露呢?更重要的是知道该如何避免这 ...

  5. [C#.NET 拾遗补漏]08:强大的LINQ

    大家好,这是 [C#.NET 拾遗补漏] 系列的第 08 篇文章,今天讲 C# 强大的 LINQ 查询.LINQ 是我最喜欢的 C# 语言特性之一. LINQ 是 Language INtegrate ...

  6. React状态管理相关

    关于React状态管理的一些想法 我最开始使用React的时候,那个时候版本还比较低(16版本以前),所以状态管理都是靠React自身API去进行管理,但当时最大的问题就是跨组件通信以及状态同步和状态 ...

  7. IO优化

    Linux性能优化之CPU.内存.IO优化 https://blog.csdn.net/zyc88888/article/details/79027944 iOS的I/O操作 https://www. ...

  8. 在Fragment 中拦截返回键

    代码如下: class XXXFrgmt : Fragment() { override fun onCreateView( inflater: LayoutInflater, container: ...

  9. Apollo(阿波罗)配置中心Java客户端使用指南使用指南

          Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境.不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限.流程治理等特性,适用于微服务配置管 ...

  10. Google Kick Start 2020 Round B T4 Wandering Robot

    题意 一个\(n \times m\)的矩形空间,起点是\((1,1)\),终点是\((n,m)\). 假设当前位于\((x,y)\): 如果当前位于最后一行,那么下一步只能走向\((x,y+1)\) ...