`
粟谷_sugu
  • 浏览: 26150 次
社区版块
存档分类
最新评论

谈谈java线程中的Join

    博客分类:
  • java
阅读更多
    最近在看java中线程相关的知识,学会很多以前感觉很模糊的知识点,今天准备记录一下线程的join方法
   开始写join方法前,先说一下java编程时会用到的一种等待-通知的模型,也就是wait和notify
   有时候我们并发编程时,一个线程修改了一个对象的值,另一个线程感知到了这个改变之后,开始进行处理其他的逻辑,这种模型的第一个线程叫做通知者,第二个线程是等待者。
实现这种模型有一种最简单的方法,就是等待者不断轮询变量的值,满足条件就开始执行自己的方法逻辑。

while(value!=desire){
    Thread.sleep(1000);
}
dosomethig();

    但是很明显,这种暴力方法不是我们追求的,所以java在设计的时候就设计了wait和notify方法,这个方法是所有对象的父类Object中的方法,所以所有的对象都拥有这种方法。另外需要注意,只有当前线程持有这个对象的锁之后才能调用对象的wait方法,当调用wait方法时,当前线程会自动释放持有的对象锁,所以这种编程模型的编程框架是如下这种
//等待者
synchronized (对象){
    while(条件不满足){
        对象.wait()
    }
    dosomething();
}
//通知者
synchronized (对象){
    改变条件
    对象.notifyAll();
}

    现在说到join,大家都知道join方法的试用场景,就是当我们在A线程调用了线程B.join(),则只有线程A会进入BLOCK状态,当线程B执行完成后,A线程才会继续执行
看一下join的实现源码,就会发现,内部也是上述等待-通知模型

public final synchronized void join(long millis)
    throws InterruptedException {
        long base = System.currentTimeMillis();
        long now = 0;

        if (millis < 0) {
            throw new IllegalArgumentException("timeout value is negative");
        }

        if (millis == 0) {
            while (isAlive()) {
                wait(0);
            }
        } else {
            while (isAlive()) {
                long delay = millis - now;
                if (delay <= 0) {
                    break;
                }
                wait(delay);
                now = System.currentTimeMillis() - base;
            }
        }
    }

    即A线程先通过synchronized,获得B线程的锁,再while判断B线程是否存活,存活则wait阻塞,直到B线程执行结束退出,线程退出时会调用notifyAll()方法。
这里之所以用while方法,是为了在被唤醒之后再确认一下是否满足了条件。
    因此A线程会等到B线程执行结束才会继续


顺便推荐《JAVA并发编程的艺术》,很厉害的书
1
0
分享到:
评论
1 楼 ZJKAICO 2018-08-01  

相关推荐

    java多线程核心编程技术

    在Java中,通过创建`Thread`对象来实现多线程。 ##### 1.2 创建线程的方式 - **继承Thread类**:创建一个Thread子类,并重写run()方法。 - **实现Runnable接口**:定义一个实现Runnable接口的类,并重写run()方法...

    简单谈谈Java 中的线程的几种状态

    Java中的线程状态是理解和优化多线程程序的关键。线程在执行过程中会经历不同的状态,这些状态反映了线程在程序中的活动情况。下面将详细解释这些状态以及它们的转换。 1. 新建状态(New): 当我们通过`new ...

    java后端面试问题整理

    在Java后端开发的求职面试中,面试官通常会围绕多个核心领域来评估候选人的技能和经验。以下是一些常见的Java后端面试问题,涵盖基础知识、设计模式、并发处理、数据库操作、框架应用等多个方面。 1. **Java基础...

    2013java面试题搜集

    21、sql语句中的letf join,right join,inner join它们是什么?? 22、http协议是怎么发送请求的?? 23、说一下get 和post的区别。 24、java会出现内存溢出的问题吗?? 25、说出几个你遇到过的异常 26、说...

    互联网高频Java后端面试题20道(适合1~3年)V1.0.22.docx

    在实际开发中,应尽量遵循避免死锁的原则,设计合理的锁获取顺序,或者使用高级并发工具,如java.util.concurrent包中的ReentrantLock,它提供了更多的控制和避免死锁的能力。 问题 8:解释一下Java中的 volatile ...

    互联网高频Java后端面试题20道(适合1~3年)V1.0.9.docx

    问题13:如何在Java中实现线程安全? 线程安全是指在多线程环境下,代码能够正确地处理共享数据,避免竞态条件和数据不一致。Java提供了多种实现线程安全的方式,如使用synchronized关键字进行同步,使用java.util....

    互联网高频Java后端面试题20道(适合1~3年)V1.0.37.docx

    问题 7:Java 中的多线程如何实现?并解释一下 synchronized 关键字的作用。 答案:在 Java 中,可以通过继承 Thread 类或实现 Runnable 接口来创建多线程。synchronized 关键字用于控制多线程对共享资源的访问,...

    JDK1.8.zip

    这个版本在Java发展历程中占据着举足轻重的地位,引入了诸多新特性,极大地提升了开发效率和代码性能。在本文中,我们将深入探讨JDK1.8的一些核心改进和亮点。 首先,JDK1.8对Lambda表达式的引入是其最显著的特征之...

    毕业季分享-美团面试经验

    【描述】:“毕业季分享----美团面试经验,谈谈java开发经验,美团和蚂蚁金服面试笔记” 在Java开发领域,深入理解语言特性、数据结构与算法、并发编程、设计模式等核心概念是必不可少的。在美团面试过程中,面试官...

    中兴华为面试试题(经典)

    - Java中的线程同步机制,如synchronized关键字、wait/notify机制、Lock接口。 - 什么是死锁,如何避免和检测死锁? - 讲解volatile关键字的作用及其实现原理。 - 如何在Java中实现线程池,分析线程池的工作原理...

    常用的工具类文件

    首先,我们来谈谈Java开发中的一些基础工具类: 1. **StringUtil**: 字符串处理是编程中最常见的任务之一。StringUtil可能包含如字符串拼接、分割、查找、替换、格式化等方法。例如,`join()`用于连接字符串数组,`...

    Kachidoki-Mredrock-Exam:红岩网校考核app

    首先,我们来谈谈Java编程。Java是一种广泛使用的面向对象的编程语言,以其“一次编写,到处运行”的特性闻名。在Kachidoki-Mredrock-Exam中,Java可能是实现app功能的主要技术。Java的应用场景广泛,包括桌面应用、...

Global site tag (gtag.js) - Google Analytics