Java并发编程基础-线程简介

简介: 章节目录1.线程定义2.使用多线程的优势3.线程优先级4.线程的状态5.Daemon 线程1.线程定义进程与线程的区别1.进程是cpu进行资源分配的独立单位,指的是程序在数据集合上的一次运行过程。

章节目录

  • 1.线程定义
  • 2.使用多线程的优势
  • 3.线程优先级
  • 4.线程的状态
  • 5.Daemon 线程

1.线程定义

进程与线程的区别

1.进程是cpu进行资源分配的独立单位,指的是程序在数据集合上的一次运行过程。
2.线程是cpu 进行调度的最小单位,在一个进程中会创建多个线程。

线程拥有的独立资源

栈中数据是线程独享的,包括局部变量、程序计数器等
堆中数据是线程共享的,如线程同时操作堆中某对象的某属性。

Java程序运行的实质

一个程序的运行不仅仅是main()方法的运行,而是main线程和多个其他线程共同运行

2.使用多线程的优势

1.充分利用更多的处理核心
2.更快的响应时间

   例如,一笔订单的创建,它包括插入订单数据,生成订单快照,发送邮件通
知买家和记录货品销售数量等, 用户从单击“订购按钮" 开始,就要等待这些操
作全部完成才能看到订购成功的结果,但是这么多的业务操作,如何才能够跟快的完成?
   在上面的场景中,我们可以使用多线程技术,即将数据一致性不强的操作派发
给其他线程处理,好处是响应用户请求的线程能更快的处理完成,缩短了响应时间,提升了用户体验。

3.线程优先级

thread.setPriority(10),线程优先级从1-10顺序排列

4.线程的状态

Java线程在运行的声明周期中可能处于如下表所示的6中状态,在给定的一个时刻,线程只能处于其中一个状态。

状态名称 说明
new 初始状态,线程被构建,但是还没有调用start()方法
runnable 运行状态,Java线程将操作系统中的就绪运行两种状态统称为"运行中"
block 阻塞状态,表示线程等待资源可用,如i/o 或者阻塞于锁
waiting 等待状态,表示线程进入等待状态,进入该状态表示当前线程需要等待其他线程做出一些特定动作(通知或中断)
time_waiting 超时等待状态,该状态不同于waiting,它是可以在指定的时间自行返回的
terminated 终止状态,表示当前线程执行完毕

如下图所示,为java线程状态变迁图:

img_e207e30e3532bbeea003a8ffbde88833.png
java线程状态变迁图

1.线程创建之后,调用start()方法,状态变更为可运行状态,待资源准备就绪后,开始运行。
2.线程执行 lockObject.wait() 方法,线程进入等待状态。
3.进入等待状态的线程依靠其他线程的通知才能返回到运行状态。
4.超时等待相当于在等待状态基础上增加超时限制,超时时间到达会自动返回到运行状态。
5.线程调用同步方法,在没有获取锁的情况下,线程会进入到阻塞状态。
6.线程在执行Runable 的run()方法后,进入终止状态。

Daemon线程
支持性线程,被用作程序中后台调度以及支持性工作。
当一个Java虚拟机中不存在非Daemon线程时,JVM将退出。
可以通过调用Thread.setDaemon(true)将线程设置为Daemon线程。
Daemon属性需要在启动线程前执行,不能在启动线程之后启动。

注意:Daemon线程被用作完成支持性工作,但在Java虚拟机退出时,Daemon线程中的finally不一定会执行。
如下代码所示:

public class Daemon {
  
    static class DaemonRunner implements Runnable {
        public void run(){
            try{
                TimeUnit.Second.sleep(10);//沉睡10s
            }finally{
                System.out.println("Daemon thread finally run");//执行类似资源回收动作
            }
        }   
    }
}

当JVM中已经没有非Daemon线程,虚拟机就要退出。JVM中所有Daemon线程需要立即终止,因此finally块并没有执行。

目录
相关文章
|
1天前
|
存储 安全 Java
Java中的容器,线程安全和线程不安全
Java中的容器,线程安全和线程不安全
7 1
|
3天前
|
设计模式 运维 安全
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第15天】在Java开发中,多线程编程是提升应用程序性能和响应能力的关键手段。然而,它伴随着诸多挑战,尤其是在保证线程安全的同时如何避免性能瓶颈。本文将探讨Java并发编程的核心概念,包括同步机制、锁优化、线程池使用以及并发集合等,旨在为开发者提供实用的线程安全策略和性能优化技巧。通过实例分析和最佳实践的分享,我们的目标是帮助读者构建既高效又可靠的多线程应用。
|
3天前
|
SQL 安全 Java
Java安全编程:防范网络攻击与漏洞
【4月更文挑战第15天】本文强调了Java安全编程的重要性,包括提高系统安全性、降低维护成本和提升用户体验。针对网络攻击和漏洞,提出了防范措施:使用PreparedStatement防SQL注入,过滤和转义用户输入抵御XSS攻击,添加令牌对抗CSRF,限制文件上传类型和大小以防止恶意文件,避免原生序列化并确保数据完整性。及时更新和修复漏洞是关键。程序员应遵循安全编程规范,保障系统安全。
|
4天前
|
Java 程序员 编译器
Java中的线程同步与锁优化策略
【4月更文挑战第14天】在多线程编程中,线程同步是确保数据一致性和程序正确性的关键。Java提供了多种机制来实现线程同步,其中最常用的是synchronized关键字和Lock接口。本文将深入探讨Java中的线程同步问题,并分析如何通过锁优化策略提高程序性能。我们将首先介绍线程同步的基本概念,然后详细讨论synchronized和Lock的使用及优缺点,最后探讨一些锁优化技巧,如锁粗化、锁消除和读写锁等。
|
5天前
|
Java 编译器
Java并发编程中的锁优化策略
【4月更文挑战第13天】 在Java并发编程中,锁是一种常见的同步机制,用于保证多个线程之间的数据一致性。然而,不当的锁使用可能导致性能下降,甚至死锁。本文将探讨Java并发编程中的锁优化策略,包括锁粗化、锁消除、锁降级等方法,以提高程序的执行效率。
12 4
|
6天前
|
Java
探秘jstack:解决Java应用线程问题的利器
探秘jstack:解决Java应用线程问题的利器
14 1
探秘jstack:解决Java应用线程问题的利器
|
1月前
|
安全 Java
深入理解Java并发编程:线程安全与性能优化
【2月更文挑战第22天】在Java并发编程中,线程安全和性能优化是两个重要的主题。本文将深入探讨这两个主题,包括线程安全的基本概念,如何实现线程安全,以及如何在保证线程安全的同时进行性能优化。
14 0
|
16天前
|
安全 Java 容器
Java并发编程:实现高效、线程安全的多线程应用
综上所述,Java并发编程需要注意线程安全、可见性、性能等方面的问题。合理使用线程池、同步机制、并发容器等工具,可以实现高效且线程安全的多线程应用。
14 1
|
26天前
|
安全 Java 开发者
Java并发编程中的线程安全性探究
在Java编程中,线程安全性是一个至关重要的问题,涉及到多线程并发访问共享资源时可能出现的数据竞争和不一致性问题。本文将深入探讨Java并发编程中的线程安全性,介绍常见的线程安全性问题以及解决方法,帮助开发者更好地理解和应对在多线程环境下的挑战。
|
26天前
|
安全 Java 开发者
Java并发编程中的线程安全性探究
在Java开发中,多线程编程是一项常见且重要的技术。本文将深入探讨Java并发编程中的线程安全性问题,从数据竞争到同步机制的选择,帮助开发者更好地理解和应对多线程环境下的挑战。
13 2