码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【面试题】LockSupport


    LockSupport

    • 1. LockSupport简介
      • 1.1 设计原理:许可
    • 2. demo
    • 3. 面试题
      • 3.1 为什么可以先唤醒线程后阻塞线程?
      • 3.2 为什么唤醒两次后阻塞两次,最终结果还是阻塞线程?

    1. LockSupport简介

    LockSupport是一个线程工具类,主要是为了park()阻塞线程,unpark()唤醒线程的时候使用。

    1.1 设计原理:许可

    park:挂起当前线程,等待一个许可
    unpark:为某个线程提供一个许可,唤醒指定线程
    注意
    调用一次unpark就➕1变成1;
    调用一次park就会消费permit,也就是变成0,同时park立即返回。
    如果再次调用park会变成阻塞(因为permit=0的时候会阻塞,一直等到permit变成1),这时候需要调用unpark会把permit置为1

    2. demo

    /**
     * 某个线程每个0.5秒输出n++,当num=20的时候,线程挂起,5s线程被唤醒,num被赋值为3继续执行
     */
    public class LockSupportDemo {
        public static void main(String[] args) {
            Thread thread = new Thread(new LockSupportTest());
            thread.start();
    
            try {
                TimeUnit.MILLISECONDS.sleep(500*10);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
    		 LockSupport.unpark(thread);
            System.out.println("5s后 unpark...");
        }
    }
    
    class LockSupportTest implements Runnable{
    
        Integer num=1;
    
        @Override
        public void run() {
            while (true){
                System.out.println("run:"+num);
                num++;
                try {
                    TimeUnit.MILLISECONDS.sleep(500);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
    
                if(num>5){
                    LockSupport.park();
                    System.out.println("park...");
                    num=3;
                }
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41

    在这里插入图片描述

    3. 面试题

    3.1 为什么可以先唤醒线程后阻塞线程?

    因为unpark获得了一个凭证,只有在调用park方法,就可以名正言顺的消费凭证,因此不会被阻塞。

    3.2 为什么唤醒两次后阻塞两次,最终结果还是阻塞线程?

    因为凭证的数量最多为1,两次unpark和一次unpark的结果是一样的,只会增加一个凭证;
    调用两次park却需要消费两个凭证,证不够,不能放行

    demo来源:https://www.bilibili.com/video/BV1jm4y1S7PQ?spm_id_from=333.337.search-card.all.click&vd_source=b901ef0e9ed712b24882863596eab0ca

  • 相关阅读:
    聚观早报 |红魔9 Pro支持165W快充;2023Q3欧洲手机市场报告
    Springboot旅游网的设计与实现xb29f计算机毕业设计-课程设计-期末作业-毕设程序代做
    CF1479D Odd Mineral Resource
    爬虫框架 Scrapy 详解
    Tomcat
    我们为什么要实现分布式计算(二)
    百度安全X盈科全球数据合规服务中心:推进数据安全及合规智能化创新领域深化合作
    玩转KubeEdge
    力扣------两数之和
    基于VUE + Echarts 实现可视化数据大屏煤改电分析系统
  • 原文地址:https://blog.csdn.net/yzx3105/article/details/126735198
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号