Java - 线程相关

简介: Java - 线程相关

线程相关


Java多线程实现方式

继承Thread,实现Runnable接口,实现Callable接口(能抛异常且有返回值,不常用)


为什么有了继承Thread方式还要有Runnable接口方式

实现接口的方式适合多个相同程序代码的线程去处理同一个资源,可以避免Java中单继承的限制


为什么JVM启动是多线程的?

因为至少启动了两个线程:主线程、垃圾回收线程


线程和进程的含义

进程:是操作系统资源分配的基本单位,正在运行的程序

线程:是任务调度和执行的基本单位,程序使用CPU的最基本单位


多线程和多进程的含义

多进程:操作系统能同时运行多个任务即程序

多线程:同一程序中有多个顺序流在执行


并发和并行的含义

并行:逻辑上同时发生,一段时间内同时运行多个程序

并发:物理上同时发生,一个时间点同时运行多个程序


线程和进程的区别

不同点  进程 线程
一个进程里有多个线程
内存 不共享内存 共享内存
资源 进程间共享文件网络资源 线程间不共享
开销 进程需要分配内存,开销较大 线程只需要分配栈和一个PC,开销较小
独立 可以独立存在 可以独立,必须依赖进程而存在
作用 进程是CPU资源分配的最小单位 线程是CPU调度的最小单位
通信 进程间的通信比较复杂因为它的数据空间独立性,需要通过操作系统,基于socket的进程间的通信机制 而线程间的通信由于多线程共享地址空间和数据空间,可直接通信,不必通过操作系统(内核的调度)


线程调度模型

分时调度模型:所有线程轮流使用CPU的使用权,平均分配每个线程占用CPU的时间片

抢占式调度模型:优先让优先级高的线程使用CPU,获得CPU时间片也越多,Java使用此模型


线程间通信——生产者消费者模式

生产者:先看是否有数据,有就等待消费者消费(wait),没有就生产,生产完后通知消费者消费

消费者:先看是否有数据,有就消费,没有就等待生产者生产,通知生产者生产数据(notify)


Java线程调度方式

线程睡眠:Thread.sleep(long millis),使线程转换到阻塞状态,当睡眠结束后,就转为就绪状态

线程等待:Object.wait(),导致当前的线程等待,直到其他线程调用此对象的notify()或notifyAll()

线程唤醒:Object.notify()方法,唤醒在此对象上等待的单个线程。

线程让步:Thread.yield(),暂停当前正在执行的线程对象,把执行机会让给相同或更高优先级的线程

线程加入:join(),等待其他线程终止


线程状态

初始状态:创建一个线程

就绪状态:线程调用start()方法

运行状态:线程被CPU调度

阻塞状态:放弃CPU使用权,暂停完毕后变回就绪状态(同步阻塞,等待阻塞,其他阻塞)

死亡状态:线程执行完或因异常退出了run()方法,线程结束了生命周期


线程状态转换

image.png

相关文章
|
2月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
177 2
|
2月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
203 1
|
3月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
160 0
|
3月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
253 16
|
4月前
|
缓存 并行计算 安全
关于Java多线程详解
本文深入讲解Java多线程编程,涵盖基础概念、线程创建与管理、同步机制、并发工具类、线程池、线程安全集合、实战案例及常见问题解决方案,助你掌握高性能并发编程技巧,应对多线程开发中的挑战。
|
4月前
|
数据采集 存储 前端开发
Java爬虫性能优化:多线程抓取JSP动态数据实践
Java爬虫性能优化:多线程抓取JSP动态数据实践
|
5月前
|
Java API 调度
从阻塞到畅通:Java虚拟线程开启并发新纪元
从阻塞到畅通:Java虚拟线程开启并发新纪元
363 83
|
5月前
|
安全 算法 Java
Java 多线程:线程安全与同步控制的深度解析
本文介绍了 Java 多线程开发的关键技术,涵盖线程的创建与启动、线程安全问题及其解决方案,包括 synchronized 关键字、原子类和线程间通信机制。通过示例代码讲解了多线程编程中的常见问题与优化方法,帮助开发者提升程序性能与稳定性。
214 0
|
5月前
|
存储 Java 调度
Java虚拟线程:轻量级并发的革命性突破
Java虚拟线程:轻量级并发的革命性突破
342 83