文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java多线程之Park和Unpark原理分析

2023-06-14 21:11

关注

这篇文章主要介绍了Java多线程之Park和Unpark原理分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

Java的优点是什么

1. 简单,只需理解基本的概念,就可以编写适合于各种情况的应用程序;2. 面向对象;3. 分布性,Java是面向网络的语言;4. 鲁棒性,java提供自动垃圾收集来进行内存管理,防止程序员在管理内存时容易产生的错误。;5. 安全性,用于网络、分布环境下的Java必须防止病毒的入侵。6. 体系结构中立,只要安装了Java运行时系统,就可在任意处理器上运行。7. 可移植性,Java可以方便地移植到网络上的不同机器。8.解释执行,Java解释器直接对Java字节码进行解释执行。

一、基本使用

它们是 LockSupport 类中的方法

// 暂停当前线程LockSupport.park(); // 恢复某个线程的运行LockSupport.unpark(暂停线程对象)

应用:先 park 再 unpark

Thread t1 = new Thread(() -> {       log.debug("start...");       sleep(1);       log.debug("park...");       LockSupport.park();       log.debug("resume...");   },"t1");   t1.start();   sleep(2);   log.debug("unpark...");   LockSupport.unpark(t1);}14:03:01.438 c.test21: [t1] - start...14:03:02.444 c.test21: [t1] - park...14:03:04.399 c.test21: [main] - unpark...14:03:04.399 c.test21: [t1] - resume...

应用:先upark后park,park不住

package com.concurrent.test4;import lombok.extern.slf4j.Slf4j;import java.util.concurrent.TimeUnit;import java.util.concurrent.locks.LockSupport;@Slf4j(topic = "c.test21:")public class Test26 {    public static void main(String[] args) throws InterruptedException{        Thread t1 = new Thread(() -> {            log.debug("start...");            try {                TimeUnit.SECONDS.sleep(1);            } catch (InterruptedException e) {                e.printStackTrace();            }            log.debug("park...");            LockSupport.park();            log.debug("resume...");        },"t1");        t1.start();        log.debug("unpark...");        LockSupport.unpark(t1);    }}14:03:35.565 c.test21: [t1] - start...14:03:35.565 c.test21: [main] - unpark...14:03:36.572 c.test21: [t1] - park...14:03:36.572 c.test21: [t1] - resume...

二、特点

与 Object 的 wait & notify 相比

三、park unpark 原理

每个线程都有自己的一个 Parker 对象,由三部分组成 _counter , _cond 和 _mutex . 打个比喻线程就像一个旅人,Parker 就像他随身携带的背包,条件变量就好比背包中的帐篷。_counter 就好比背包中的备用干粮(0 为耗尽,1 为充足)调用 park 就是要看需不需要停下来歇息,如果备用干粮耗尽,那么钻进帐篷歇息. 如果备用干粮充足,那么不需停留,继续前进调用 unpark,就好比令干粮充足.如果这时线程还在帐篷,就唤醒让他继续前进,如果这时线程还在运行,那么下次他调用 park 时,仅是消耗掉备用干粮,不需停留继续前进,因为背包空间有限,多次调用 unpark 仅会补充一份备用干粮

Java多线程之Park和Unpark原理分析

Java多线程之Park和Unpark原理分析

Java多线程之Park和Unpark原理分析

四、park/unpark 原理总结

park 操作

获取当前线程关联的 Parker 对象。

将计数器置为 0,同时检查计数器的原值是否为 1,如果是则放弃后续操作。

在互斥量上加锁。

在条件变量上阻塞,同时释放锁并等待被其他线程唤醒,当被唤醒后,将重新获取锁。

当线程恢复至运行状态后,将计数器的值再次置为 0。
释放锁。

unpark 操作:

获取目标线程关联的 Parker 对象(注意目标线程不是当前线程)。

在互斥量上加锁。

将计数器置为 1。

唤醒在条件变量上等待着的线程。

释放锁。

感谢你能够认真阅读完这篇文章,希望小编分享的“Java多线程之Park和Unpark原理分析”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯