热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

c++多线程编程_Java并发编程系列:线程的五大状态,以及线程之间的通信与协作...

之前分享过了Java并发编程相关的线程锁、线程池、死锁、以及常用并发工具类(JUC)等:史上最强多线程面试44题和答案:线程锁线程池线程同步等Java并发编程系列&#
8c20a279b6c17e5ee9f92b725fac013c.png

之前分享过了Java并发编程相关的线程锁、线程池、死锁、以及常用并发工具类(JUC)等:

史上最强多线程面试44题和答案:线程锁+线程池+线程同步等

Java并发编程系列:CountDownLatch、Semaphore等4大并发工具类详解

Java并发编程系列:4种常用Java线程锁的特点,性能比较、使用场景

Java并发编程系列:Java线程池的使用方式,核心运行原理、以及注意事项

今天主要分享多线程状态流转与通信,这也是面试中必考的基础知识点。

d0a81b8215e0a97cd6bbe019ee628e94.png

多线程的基本概念

1.进程

进程是操作系统进行资源分配和调度的基本单位。

927081e7ce1f7702f6af1bf048ccb4aa.png

2.线程

线程是进程中的一个执行单元,负责当前进程中程序的执行,一个进程中至少有一个线程。

3.多线程

什么是多线程呢?即就是一个程序中有多个线程在同时执行。

线程的生命周期

82201088f090ae53ce142e6388a1e891.png

java中每个线程都需经历新生、就绪、运行、阻塞和死亡五种状态,线程从新生到死亡的状态变化称为生命周期。

1.新建状态

使用 new Thread 类或其子类建立一个线程对象后,该线程对象就处于新建状态。

2.就绪状态

调用了start()方法之后,该线程就进入就绪状态(就绪队列中),等待JVM里线程调度器的调度。

3.运行状态

执行 run(),此时线程便处于运行状态。处于运行状态的线程最为复杂,它可以变为阻塞状态、就绪状态和死亡状态。

4.阻塞状态

如果一个线程执行了sleep(睡眠)、suspend(挂起)等方法,失去所占用资源之后,该线程就从运行状态进入阻塞状态。

5.死亡状态

一个运行状态的线程完成任务或者其他终止条件发生时,该线程就切换到终止状态。

线程的调度策略

线程调度是指系统为线程分配处理器使用权的过程。

Java使用的线程调度是抢占式调度,在抢占式调度下,优先级最高的任务一直执行,直到它进入等待或死亡状态或更高优先级的任务出现,优先级高的线程比优先级低的线程优先执行。

在Java多线程环境中,为保证所有线程的执行能按照一定的规则执行,JVM实现了一个线程调度器,它定义了线程调度的策略,在JVM中体现为让可运行池中优先级高的线程拥有CPU使用权。

线程之间的通信与协作

37d942f3a9371793bbe8bf3f0f0b84f8.png

上面比较清楚的显示了线程的状态流转,其实重点主要是掌握运行、阻塞、就绪之间的通信机制。

1.sleep()和yield()和join()

1)sleep()方法作用:让当前线程睡眠一段时间,期间不会释放任何持有的锁。

2) yield()方法作用:让出该线程的时间片给其它线程。线程调用了yield()方法,表示放弃当前获得的CPU时间片,回到就绪状态。最后由线程调度重新选择就绪状态的线程分配CPU资源。

3)join()方法作用:暂停当前线程,等待被调用线程指向结束之后再继续执行。

注意:
1)sleep(long)方法仅释放CPU使用权,锁仍然占用。
2)调用join()的时候,当前线程不会释放掉锁。

2.wait()和notify() 方法和notifyAll()方法

1)wait()方法的作用:让该线程处于等待状态。

2)notify()方法的作用:唤醒处于wait的线程。

3)notifyAll()方法的作用:唤醒所有处于wait状态的线程。

注意:
1)wait()方法会释放CPU执行权 和 占有的锁。
2) 线程调用wait()方法后,让该线程处于等待状态。进入这个状态后,是不能自动唤醒的,必须依靠其他线程调用notify()或notifyAll()方法才能被唤醒。wait和notify必须配套使用,即必须使用同一把锁调用。

觉得不错请点赞支持下。

----end----

0e2955c6cf6e36beb70bcedc4caf749d.png



推荐阅读
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 深入解析JVM垃圾收集器
    本文基于《深入理解Java虚拟机:JVM高级特性与最佳实践》第二版,详细探讨了JVM中不同类型的垃圾收集器及其工作原理。通过介绍各种垃圾收集器的特性和应用场景,帮助读者更好地理解和优化JVM内存管理。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • FinOps 与 Serverless 的结合:破解云成本难题
    本文探讨了如何通过 FinOps 实践优化 Serverless 应用的成本管理,提出了首个 Serverless 函数总成本估计模型,并分享了多种有效的成本优化策略。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 本文总结了Java程序设计第一周的学习内容,涵盖语言基础、编译解释过程及基本数据类型等核心知识点。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • 本文详细介绍了Grand Central Dispatch (GCD) 的核心概念和使用方法,探讨了任务队列、同步与异步执行以及常见的死锁问题。通过具体示例和代码片段,帮助开发者更好地理解和应用GCD进行多线程开发。 ... [详细]
  • 深入理解Java中的volatile、内存屏障与CPU指令
    本文详细探讨了Java中volatile关键字的作用机制,以及其与内存屏障和CPU指令之间的关系。通过具体示例和专业解析,帮助读者更好地理解多线程编程中的同步问题。 ... [详细]
  • 本文详细探讨了Netty中Future及其子类的设计与实现,包括其在并发编程中的作用和具体应用场景。我们将介绍Future的继承体系、关键方法的实现细节,并讨论如何通过监听器和回调机制来处理异步任务的结果。 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
author-avatar
朱永红2602897625
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有