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

相关文章
|
21天前
|
Java 开发者
Java多线程编程中的常见误区与最佳实践####
本文深入剖析了Java多线程编程中开发者常遇到的几个典型误区,如对`start()`与`run()`方法的混淆使用、忽视线程安全问题、错误处理未同步的共享变量等,并针对这些问题提出了具体的解决方案和最佳实践。通过实例代码对比,直观展示了正确与错误的实现方式,旨在帮助读者构建更加健壮、高效的多线程应用程序。 ####
|
23天前
|
安全 Java UED
深入浅出Java多线程编程
【10月更文挑战第40天】在Java的世界中,多线程是提升应用性能和响应能力的关键。本文将通过浅显易懂的方式介绍Java中的多线程编程,从基础概念到高级特性,再到实际应用案例,带你一步步深入了解如何在Java中高效地使用多线程。文章不仅涵盖了理论知识,还提供了实用的代码示例,帮助你在实际开发中更好地应用多线程技术。
40 5
|
12天前
|
设计模式 Java 开发者
Java多线程编程的陷阱与解决方案####
本文深入探讨了Java多线程编程中常见的问题及其解决策略。通过分析竞态条件、死锁、活锁等典型场景,并结合代码示例和实用技巧,帮助开发者有效避免这些陷阱,提升并发程序的稳定性和性能。 ####
|
10天前
|
存储 监控 小程序
Java中的线程池优化实践####
本文深入探讨了Java中线程池的工作原理,分析了常见的线程池类型及其适用场景,并通过实际案例展示了如何根据应用需求进行线程池的优化配置。文章首先介绍了线程池的基本概念和核心参数,随后详细阐述了几种常见的线程池实现(如FixedThreadPool、CachedThreadPool、ScheduledThreadPool等)的特点及使用场景。接着,通过一个电商系统订单处理的实际案例,分析了线程池参数设置不当导致的性能问题,并提出了相应的优化策略。最终,总结了线程池优化的最佳实践,旨在帮助开发者更好地利用Java线程池提升应用性能和稳定性。 ####
|
12天前
|
缓存 Java 开发者
Java多线程编程的陷阱与最佳实践####
本文深入探讨了Java多线程编程中常见的陷阱,如竞态条件、死锁和内存一致性错误,并提供了实用的避免策略。通过分析典型错误案例,本文旨在帮助开发者更好地理解和掌握多线程环境下的编程技巧,从而提升并发程序的稳定性和性能。 ####
|
6天前
|
安全 算法 Java
Java多线程编程中的陷阱与最佳实践####
本文探讨了Java多线程编程中常见的陷阱,并介绍了如何通过最佳实践来避免这些问题。我们将从基础概念入手,逐步深入到具体的代码示例,帮助开发者更好地理解和应用多线程技术。无论是初学者还是有经验的开发者,都能从中获得有价值的见解和建议。 ####
|
6天前
|
Java 调度
Java中的多线程编程与并发控制
本文深入探讨了Java编程语言中多线程编程的基础知识和并发控制机制。文章首先介绍了多线程的基本概念,包括线程的定义、生命周期以及在Java中创建和管理线程的方法。接着,详细讲解了Java提供的同步机制,如synchronized关键字、wait()和notify()方法等,以及如何通过这些机制实现线程间的协调与通信。最后,本文还讨论了一些常见的并发问题,例如死锁、竞态条件等,并提供了相应的解决策略。
23 3
|
7天前
|
监控 Java 开发者
深入理解Java中的线程池实现原理及其性能优化####
本文旨在揭示Java中线程池的核心工作机制,通过剖析其背后的设计思想与实现细节,为读者提供一份详尽的线程池性能优化指南。不同于传统的技术教程,本文将采用一种互动式探索的方式,带领大家从理论到实践,逐步揭开线程池高效管理线程资源的奥秘。无论你是Java并发编程的初学者,还是寻求性能调优技巧的资深开发者,都能在本文中找到有价值的内容。 ####
|
12天前
|
缓存 Java 开发者
Java多线程并发编程:同步机制与实践应用
本文深入探讨Java多线程中的同步机制,分析了多线程并发带来的数据不一致等问题,详细介绍了`synchronized`关键字、`ReentrantLock`显式锁及`ReentrantReadWriteLock`读写锁的应用,结合代码示例展示了如何有效解决竞态条件,提升程序性能与稳定性。
37 5
|
10天前
|
监控 Java 数据库连接
Java线程管理:守护线程与用户线程的区分与应用
在Java多线程编程中,线程可以分为守护线程(Daemon Thread)和用户线程(User Thread)。这两种线程在行为和用途上有着明显的区别,了解它们的差异对于编写高效、稳定的并发程序至关重要。
19 2