【高薪程序员必看】万字长文拆解Java并发编程!(2 2-2)

简介: 📌 核心痛点暴击:1️⃣ 面了8家都被问synchronized锁升级?一张图看懂偏向锁→重量级锁全过程!2️⃣ 线程池参数不会配?高并发场景下这些参数调优救了项目组命!3️⃣ volatile双重检测单例模式到底安不安全?99%人踩过的内存可见性大坑!💡 独家亮点抢先看:✅ 图解JVM内存模型(JMM)三大特性,看完再也不怕指令重排序✅ 手撕ReentrantLock源码,AQS队列同步器实现原理大揭秘✅ 全网最细线程状态转换图(附6种状态转换触发条件表)


目录

2.4.3. 线程优先级

2.4.4. 案例-防止CPU占用100%

2.4.5. join

2.4.6. interrupt

2.4.7. LockSupport.park()

2.4.8. 不推荐的方法

2.5. 主线程与守护线程

2.6. 线程状态

2.6.1. 五种状态-操作系统

2.6.2. 六种状态-JavaAPI


2.4.3. 线程优先级

  • 线程优先级会提示任务调度器优先调度该线程,但仅仅是一个提示,具体做法还是得看任务调度器
  • CPU忙时,优先级高的线程得到更多的时间片,CPU空闲时,优先级几乎没用

2.4.4. 案例-防止CPU占用100%

在没有利用CPU来计算时,不要让while(true)死循环空转浪费CPU,这时可以使用yield或sleep或wait,让出CPU的使用权给其他程序

  • sleep方法适用于无需同步锁的场景
@Slf4j
public class ThreadSleepMethod {
    public static void main(String[] args) throws InterruptedException {
        while (true) {
            Thread.sleep(50);
        }
    }
}

image.gif

  • wait和yield方法都需要加锁,并需要唤醒操作,适用于需要进行同步的场景

2.4.5. join

join:

  • 等待调用此方法的线程运行结束,适用于需要同步的场景
  • 参数long类型:指定等待最大时间
@Slf4j
public class ThreadJoinMethod {
    public static int result = 0;
    public static void main(String[] args) throws InterruptedException {
        method();
    }
    public static void method() throws InterruptedException {
        log.debug("开始");
        Thread t1 = new Thread(()->{
            log.debug("开始");
            try {
                Thread.sleep(1000);
                result = 10;
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
        },"t1");
        t1.start();
        t1.join();
        log.debug("结果为:{}",result);
        log.debug("结束");
    }
}

image.gif

2.4.6. interrupt

interrupt:

  • 打断处于阻塞状态的线程(调用了sleep,wait,join方法的线程)时,会清空打断标记(false)
  • 打断处于运行状态的线程时,不会清空打断标记(true),不会强制终止线程,然后线程可以根据打断标记来决定是否继续运行(Thread.currentThread().isInterrupt())

isInterrupt:

  • 获取打断标记(true/false)

2.4.7. LockSupport.park()

  • 打断park线程时不会清空打断状态,如果打断标记已经是true,则park不会生效

2.4.8. 不推荐的方法

image.gif 编辑

2.5. 主线程与守护线程

默认情况,Java进程会等待所有线程运行结束之后才会结束.

守护线程是只要其他非守护线程运行结束了,即时守护线程的代码没有执行完毕,也会强制结束守护线程.

  • 守护线程通过线程调用setDaemon来设置当前线程是否为守护线程
  • 守护线程应用于垃圾回收器线程,Tomcat中的Acceptor,Poller线程
  • 当所有线程都停止了,垃圾回收线程会强制结束
  • 当Tomcat接收到shutdown命令后,不会等待Acceptor,Poller线程处理完当前请求,而是直接结束

2.6. 线程状态

2.6.1. 五种状态-操作系统

image.gif 编辑

  • 初始状态:仅仅在语言层面上创建了线程对象,还没有与操作系统关联
  • 可运行状态:线程对象已经与操作系统关联,可以运行,但还未获得CPU时间片
  • 运行状态:线程对象已经获得CPU时间片并正在运行,当时间片用完时,进行线程上下文切换,变为可运行状态
  • 阻塞状态:运行状态调用阻塞API就会进行线程上下文切换进入阻塞状态,这时CPU不会分发时间片给阻塞状态中的线程
  • 例如线程进行BIO读写文件时就会进入阻塞状态,等待BIO结束后,由操作系统唤醒阻塞中的线程,转变为可运行状态
  • 阻塞状态中的线程一直不被唤醒,CPU就不会考虑分发时间片
  • 终止状态:表示当前线程生命周期已经结束,不会转变为其他状态了

2.6.2. 六种状态-JavaAPI

image.gif 编辑

  • new:线程创建但还未调用start方法时,是new状态
  • runnable:线程创建后调用start方法时,是runnable状态
  • blocked:线程获取对象锁,但此对象锁已被其他对象获取且并未释放时,是blocked状态
  • waiting:线程调用没有时限等待方法(join,sleep等)时,是time状态
  • time_waiting:线程调用指定时限的休眠方法(sleep,wait等)时,是time_waiting状态
  • terminated:线程代码运行结束时,是terminated状态


目录
相关文章
|
19天前
|
人工智能 Kubernetes Java
回归开源,两位 Java 和 Go 程序员分享的开源贡献指引
Higress是一个基于Istio和Envoy的云原生API网关,支持AI功能扩展。它通过Go/Rust/JS编写的Wasm插件提供可扩展架构,并包含Node和Java的console模块。Higress起源于阿里巴巴,解决了Tengine配置重载及gRPC/Dubbo负载均衡问题,现已成为阿里云API网关的基础。本文介绍Higress的基本架构、功能(如AI网关、API管理、Ingress流量网关等)、部署方式以及如何参与开源贡献。此外,还提供了有效的开源贡献指南和社区交流信息。
249 34
|
7天前
|
Java 数据库连接 API
2025 更新必看:Java 编程基础入门级超级完整版指南
本教程为2025更新版Java编程基础入门指南,涵盖开发环境搭建(SDKMAN!管理JDK、VS Code配置)、Java 17+新特性(文本块、Switch表达式增强、Record类)、面向对象编程(接口默认方法、抽象类与模板方法)、集合框架深度应用(Stream API高级操作、并发集合)、模式匹配与密封类等。还包括学生成绩管理系统实战项目,涉及Maven构建、Lombok简化代码、JDBC数据库操作及JavaFX界面开发。同时提供JUnit测试、日志框架使用技巧及进阶学习资源推荐,助你掌握Java核心技术并迈向高级开发。
65 5
|
13天前
|
JavaScript 前端开发 Java
Java 编程进阶实操中工具集整合组件封装方法与使用指南详解
本文详细介绍Hutool工具集和图书管理系统相关组件的封装方法及使用示例。通过通用工具类封装(如日期格式化、字符串处理、加密等)、数据库操作封装(结合Hutool DbUtil与MyBatis)、前端Vue组件封装(图书列表与借阅表单)以及后端服务层封装(业务逻辑实现与REST API设计),帮助开发者提升代码复用性与可维护性。同时,提供最佳实践建议,如单一职责原则、高内聚低耦合、参数配置化等,助力高效开发。适用于Java编程进阶学习与实际项目应用。
80 10
|
7天前
|
Oracle Java 关系型数据库
java 编程基础入门级超级完整版教程详解
这份文档是针对Java编程入门学习者的超级完整版教程,涵盖了从环境搭建到实际项目应用的全方位内容。首先介绍了Java的基本概念与开发环境配置方法,随后深入讲解了基础语法、控制流程、面向对象编程的核心思想,并配以具体代码示例。接着探讨了常用类库与API的应用,如字符串操作、集合框架及文件处理等。最后通过一个学生成绩管理系统的实例,帮助读者将理论知识应用于实践。此外,还提供了进阶学习建议,引导学员逐步掌握更复杂的Java技术。适合初学者系统性学习Java编程。资源地址:[点击访问](https://pan.quark.cn/s/14fcf913bae6)。
52 2
|
13天前
|
前端开发 Java 数据库连接
Java 编程进阶实操之工具集整合应用指南
本文聚焦Java编程进阶实操,涵盖并发编程、性能优化及数据库操作优化等核心知识点,并结合Hutool、Postman、Git等实用工具,提供从理论到实践的学习路径。通过小型图书管理系统实战项目,详细解析技术选型与实现步骤,助力开发者掌握Spring Boot、MyBatis等框架应用。同时展望Java新特性与技术趋势,为职业发展奠定基础。资源链接:[点此获取](https://pan.quark.cn/s/14fcf913bae6)。
46 1
|
23天前
|
Java 开发者
Java编程实用技巧:提升代码质量与开发效率
Java作为一门成熟且广泛应用的编程语言,掌握一些实用技巧可以显著提高开发效率和代码质量。以下是值得Java开发者掌握的实用技巧:
42 6
|
8天前
|
人工智能 Java API
Java并发编程之Future与FutureTask
本文深入解析了Future接口及其实现类FutureTask的原理与使用。Future接口定义了获取任务结果、取消任务及查询任务状态的规范,而FutureTask作为其核心实现类,结合了Runnable与Future的功能。文章通过分析FutureTask的成员变量、状态流转、关键方法(如run、set、get、cancel等)的源码,展示了异步任务的执行与结果处理机制。最后,通过示例代码演示了FutureTask的简单用法,帮助读者更直观地理解其工作原理。适合希望深入了解Java异步编程机制的开发者阅读。
|
24天前
|
网络协议 Java 大数据
【高薪程序员必看】万字长文拆解Java并发编程!(1)
📌 核心痛点暴击:1️⃣ 面了8家都被问synchronized锁升级?一张图看懂偏向锁→重量级锁全过程!2️⃣ 线程池参数不会配?高并发场景下这些参数调优救了项目组命!3️⃣ volatile双重检测单例模式到底安不安全?99%人踩过的内存可见性大坑!💡 独家亮点抢先看:✅ 图解JVM内存模型(JMM)三大特性,看完再也不怕指令重排序✅ 手撕ReentrantLock源码,AQS队列同步器实现原理大揭秘✅ 全网最细线程状态转换图(附6种状态转换触发条件表)
45 0
|
15天前
|
算法 Java 调度
Java多线程基础
本文主要讲解多线程相关知识,分为两部分。第一部分涵盖多线程概念(并发与并行、进程与线程)、Java程序运行原理(JVM启动多线程特性)、实现多线程的两种方式(继承Thread类与实现Runnable接口)及其区别。第二部分涉及线程同步(同步锁的应用场景与代码示例)及线程间通信(wait()与notify()方法的使用)。通过多个Demo代码实例,深入浅出地解析多线程的核心知识点,帮助读者掌握其实现与应用技巧。
|
4月前
|
存储 监控 Java
【Java并发】【线程池】带你从0-1入门线程池
欢迎来到我的技术博客!我是一名热爱编程的开发者,梦想是编写高端CRUD应用。2025年我正在沉淀中,博客更新速度加快,期待与你一起成长。 线程池是一种复用线程资源的机制,通过预先创建一定数量的线程并管理其生命周期,避免频繁创建/销毁线程带来的性能开销。它解决了线程创建成本高、资源耗尽风险、响应速度慢和任务执行缺乏管理等问题。
259 60
【Java并发】【线程池】带你从0-1入门线程池