线程

什么是线程

操作系统调度的最小单元就是线程,也叫轻量级进程。

为什么要使用多线程

  1. 多线程程序能够更有效率地利用多处理器核心。
  2. 用户响应时间更快。
  3. 方便程序员将程序模型映射到Java提供的多线程编程模型上。

线程的状态

1. 初始态 NEW

线程被构建,但是还没有调用start()方法调用。

2 运行态 RUNNABLE

运行态又分为就绪态和运行态:

  • 就绪态:该状态下线程已经具备执行所需要的所有资源,只等CPU分配执行权就能运行。所有的就绪态线程都排在就绪队列中。
  • 运行态:获取CPU执行权的正在执行的线程。每个CPU同时只有一条运行态的线程。

3.阻塞态

表示线程阻塞于锁。

  • 当线程请求一个资源失败的时候,就会进入阻塞态。Java中阻塞态就是指线程获取锁失败后进入的状态。是被动进入的。
  • 所有阻塞态的线程被排在阻塞队列当中。
  • 处于阻塞态的线程会不断请求资源,当请求成功的时候,就会又进入就绪队列等待执行。

4.等待态

  • 当前线程中调用wait join park时,线程就会进入等待态。
  • 等待态的线程放在等待队列中。
  • 需要又其他线程的唤醒才行。
  • 会释放资源。

5.超时等待态

  • 当线程中调用sleep wait join parkNanos parkUntil时,就是让线程进入等待态。
  • 与等待态不同,不是因为请求不到资源,这是主动进入的,需要其他线程对其进行唤醒。
  • 等待态的线程没有CPU执行权和占有资源。
  • 到了超时时间后进入阻塞队列,开始竞争锁。

6.终止态

线程执行结束后的状态。

线程状态转换

  • 初始态 ——> 就绪态
    当调用线程对象的start()方法就会进入就绪态。当就绪态队列中没有线程,那就直接进入运行态。
  • 就绪态 ——> 运行态
    由系统调度。
  • 运行态 ——> 就绪态
    调用Thread.yield()函数 或者 系统调度完成。
  • 运行态 ——> 阻塞态
    线程获取锁失败。
  • 阻塞态 ——> 就绪态
    获取到锁。
  • 运行态 ——> 等待态
    调用Object.wait() 方法,其调用必须是在同步块内部由同步块的锁对象调用。
    调用Thread.join() LockSupport.part() 方法。
  • 等待态 ——> 就绪态
    锁对象被调用了Object.notify() 方法,并且等待的线程不需要锁。
    还有Object.notifyAll() LockSupport.unpark(Tread) 方法。
  • 等待态 ——> 阻塞态
    锁对象 notify的时候,被等地啊线程还需要锁同步。

知识点

  • wait方法会释放CPU的执行权和占有的锁。
  • sleep方法会释放CPU的使用权,但是任然占有锁;线程被放入超时等待队列,它会使线程较长时间得不到运行。
  • wait和notify必须配套使用,必须使用同一把锁。
  • wait和notify必须放在一个同步块中。
  • notify和notifyAll的区别在于,前者只唤醒等待队列中的一个线程,而后者是所有线程。

Daemon 线程

作用

是一种支持型线程,主要用作程序中后台调度和支持性共工作。

如果一个Java虚拟机中不存在非Deamon线程的时候,Java虚拟机就会退出,因为不会再有任务了呀。

Java线程使用

参考

Java并发编程的艺术(五)——线程和线程的状态的更多相关文章

  1. Java并发编程的艺术(五)——中断

    什么是中断? 在Java中没有办法立即停止一条线程,然而停止线程却显得尤为重要,如取消一个耗时操作.因此,Java提供了一种用于停止线程的机制——中断. 中断只是一种协作机制,Java没有给中断增加任 ...

  2. Java并发编程的艺术(七)——线程间的通信

    为什么需要线程间通信 让线程之间合作,提高运行效率. volatile和synchronized关键字 实现原理 这两个方式都是采用共享内存的方式进行通信,通过同步机制保证数据可见性和排他性. 特点 ...

  3. Java并发编程的艺术(十一)——Executor与线程池

    Executor框架简介 从JDK5开始,把工作单元和执行机制分离开来了,工作的单元包括Runnable和Callable,执行机制就是由Executor框架提供. Executor两级调度模型 Ho ...

  4. Java并发编程的艺术(六)——线程间的通信

    多条线程之间有时需要数据交互,下面介绍五种线程间数据交互的方式,他们的使用场景各有不同. 1. volatile.synchronized关键字 PS:关于volatile的详细介绍请移步至:Java ...

  5. java并发编程笔记(五)——线程安全策略

    java并发编程笔记(五)--线程安全策略 不可变得对象 不可变对象需要满足的条件 对象创建以后其状态就不能修改 对象所有的域都是final类型 对象是正确创建的(在对象创建期间,this引用没有逸出 ...

  6. 读《Java并发编程的艺术》(一)

    离开博客园很久了,自从找到工作,到现在基本没有再写过博客了.在大学培养起来的写博客的习惯在慢慢的消失殆尽,感觉汗颜.所以现在要开始重新培养起这个习惯,定期写博客不仅是对自己学习知识的一种沉淀,更是在督 ...

  7. Java并发编程的艺术读书笔记(2)-并发编程模型

    title: Java并发编程的艺术读书笔记(2)-并发编程模型 date: 2017-05-05 23:37:20 tags: ['多线程','并发'] categories: 读书笔记 --- 1 ...

  8. Java并发编程的艺术读书笔记(1)-并发编程的挑战

    title: Java并发编程的艺术读书笔记(1)-并发编程的挑战 date: 2017-05-03 23:28:45 tags: ['多线程','并发'] categories: 读书笔记 --- ...

  9. 那些年读过的书《Java并发编程实战》和《Java并发编程的艺术》三、任务执行框架—Executor框架小结

    <Java并发编程实战>和<Java并发编程的艺术>           Executor框架小结 1.在线程中如何执行任务 (1)任务执行目标: 在正常负载情况下,服务器应用 ...

  10. Java并发编程的艺术(三)——volatile

    1. 并发编程的两个关键问题 并发是让多个线程同时执行,若线程之间是独立的,那并发实现起来很简单,各自执行各自的就行:但往往多条线程之间需要共享数据,此时在并发编程过程中就不可避免要考虑两个问题:通信 ...

随机推荐

  1. python实战GUI界面+mysql

    前言 前面用tkinter做了一个巨丑的GUI界面,今天想把它变漂亮起来,重新找回page做了一个界面,它也是基于tkinter开发的所见即所得的界面编辑器,前面因为代码搞不明白没用上,现在重新研究一 ...

  2. CTDB使用radosobject作为lockfile

    前言 服务器的服务做HA有很多种方式,其中有一种就是是用CTDB,之前这个是独立的软件来做HA的,现在已经跟着SAMBA主线里面了,也就是跟着samba发行包一起发行 之前CTDB的模式是需要有一个共 ...

  3. Java web项目JXl导出excel,(从eclipse上移动到tomact服务器上,之路径更改)

    我用的是jxl导出excel,比较简单,最开始我是固定路径不能选择,很局限,后来改了,而且固定路径当把项目放在服务器上时,路径不可行. 在网上各位大神的帮助成功设置响应头,并且可选保存路径. 1.前端 ...

  4. [代码审计Day2] filter_var函数缺陷代码审计

    简介 // composer require "twig/twig" require 'vendor/autoload.php'; class Template { private ...

  5. OWASP固件安全性测试指南

    OWASP固件安全性测试指南 固件安全评估,英文名称 firmware security testing methodology 简称 FSTM.该指导方法主要是为了安全研究人员.软件开发人员.顾问. ...

  6. leetcode 108 和leetcode 109

    //感想:有时候啊,对于一道题目,如果知道那个点在哪,就会非常简单,比如说这两题,将有序的数组转换为二叉搜索树, 有几个点: 1.二叉搜索树:对于某个节点,它的左节点小于它,它的右节点大于它,这是二叉 ...

  7. C语言讲义——“编译、链接”

    HelloWorld 最简HelloWorld include <stdio.h> 指令:标准输入输出头文件. main函数 C语言程序的唯一入口. #include <stdio. ...

  8. partial conv

    Image Inpainting for Irregular Holes Using Partial Convolutions pytorch代码 论文贡献: 提出了部分卷积(partial conv ...

  9. ConvTranspose2d

    nn.ConvTranspose2d的功能是进行反卷积操作 nn.ConvTranspose2d(in_channels, out_channels, kernel_size, stride=1, p ...

  10. 腾讯云linux系统部署项目无法通过外网访问

    最近尝试使用了一下腾讯去的linux系统服务器,但是却遇到各种问题,下面记录的问题是项目部署完成后却无法通过外网访问. 服务器:腾讯云 系统 :CentOS 8.0 64位 处理思路:通过度娘百般摸索 ...