【JUC】不可不知的Java多线程的基础概念

Java多线程的相关概念

并发和并行有什么区别?

进程、线程和管程有什么区别?

......

不知道有没有面试的小伙伴被问到这些问题,我前不久参加的一个面试就恰好问到了这些,今天这篇文章,我们就介绍下一些Java多线程的基础概念。

并发 concurrent

  • 同一实体上的多个事件
  • 同一台机器上交替处理多个任务
  • 同一时刻,只有一个事件在发生

并行 parallel

  • 不同实体上的多个事件
  • 是在多个处理器上同时处理多个任务
  • 同一时刻,真的有多个事情在发生

并发 vs. 并行

并发和并行的主要区别在于:并发任务在不同的时间点上交替执行,而并行任务在同一时间点上同时执行;并发是通过在不同时间点上共享资源来处理多个任务来提升效率的,而并行则是通过利用多个资源(如多个 CPU 核心)同时处理任务来提升效率的。

进程

在系统中运行一个应用程序就是一个进程,每一个进程都有自己的内存空间和系统资源,所以进程是CPU进行资源分配的最小单位

线程

也称轻量级进程,一个进程中会有一个或者多个线程,是CPU调度的最小单位

管程

Monitor(监视器),是一种同步机制,也就是我们平时所说的"锁",他的任务是确保同一时间只有一个线程可以访问被保护的数据和代码。JVM紫红的同步是基于进入和退出Monitor来实现的,每个对象都会有一个Monitor对象(会和Java对象一起创建和销毁,底层由C++实现的)。

JVM虚拟机支持方法级别 以及方法内部一段指令序列的同步(都是通过管程即Monitor实现的),方法级的同步是隐式的(无需字节码指令控制),是在方法的调用和返回操作中,虚拟机可以从方法常量池中的方法表结构中是否有"ACC_SYNCHRONIZED"这个访问标志来判断该方法是否被声明为同步方法。在调用方法时,会先判断是否设置了"ACC_SYNCHRONIZED"访问标志,如果设置了,就要求执行线程先成功持有管程,然后才能执行方法,最后的在方法完成时释放管程(无论方法执行成功与否,如果方法抛出了异常,也会在异常抛到同步方法边界之外时自动释放)。

而对于一段指令集序列的同步通常是Java中的synchronized语句块来表示(monitorentermonitorexit),实现synchronized关键字需要Java编译器和Java虚拟机两者共同协作支持。

用户线程和守护线程

一般不做特殊说明配置,默认都是用户线程

用户线程 User Thread

系统的工作线程,完成某个程序需要完成的业务操作

守护线程 Daemon Thread

  • 是一种特殊的线程,是为其他线程服务的,在后台默默地完成一些系统性的服务(比如垃圾回收)
  • 守护线程作为一个服务线程,没有服务对象就没有必要继续运行了,如果用户线程全部结束了,意味着程序需要完成的业务操作已经结束了,系统可以退出了,所以当系统只剩下守护线程的时候,Java虚拟机就会自动退出

线程的daemon属性

源码解读

  • 返回true表示守护线程
  • 返回false表示用户线程

总结

  • 如果用户线程全部结束,就意味着程序需要完成的业务操作已经结束了,守护线程随着JVM一同结束工作。

  • setDaemon(true)方法必须在start()之前设置,否则报IllegalThreadStateException异常(不能把一个正在执行的常规线程设置为守护线程)

相关推荐
顽石九变5 分钟前
【SpringBoo3】SpringBoot项目Web拦截器使用
spring boot·后端
小韩学长yyds5 分钟前
Java调用第三方HTTP接口:从入门到实战
java·开发语言·http
苏十八7 分钟前
JavaEE Servlet02
java·服务器·网络·java-ee·json
爬菜12 分钟前
异常(5)
java
梦兮林夕22 分钟前
从零掌握 Gin 参数解析与验证
后端·go·gin
bobz96532 分钟前
IPSec IKE PSK 与扩展支持Xauth账户密码
后端
supermodule32 分钟前
基于flask的一个数据展示网页
后端·python·flask
苹果酱056736 分钟前
Golang的数据库备份与恢复
java·vue.js·spring boot·mysql·课程设计
315356691341 分钟前
manus邀请码申请手把手教程
前端·后端·面试
青石路1 小时前
经由同个文件多次压缩的文件MD5都不一样问题排查,感慨AI的强大!
java·后端