线程

什么是线程

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

为什么要使用多线程

  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. 源码分析:ReentrantReadWriteLock之读写锁

    简介 ReentrantReadWriteLock 从字面意思可以看出,是和重入.读写有关系的锁,实际上 ReentrantReadWriteLock 确实也是支持可重入的读写锁,并且支持公平和非公平 ...

  2. JAVA学习准备

    Java学习准备 MarkDown语法学习 字体 hello,world! hello,world! hello,world! 引用 即使最小的帆也能远航 分割线 图片 超链接 点击跳转到我的邮箱 列 ...

  3. ceph bluestore的db分区应该预留多大的空间

    前言 关于bluestore的db应该预留多少空间,网上有很多资料 如果采用默认的 write_buffer_size=268435456 大小的话 那么几个rocksdb的数据等级是 L0: in ...

  4. rbd的删除回收站功能

    前言 rbd 提供了一个回收站功能,这个是属于防呆设计,防止误操作删除rbd引起无法恢复的情况,rbd正常情况下的删除是马上会在后台回收空间的,这个也听说过有人做过误删除的操作,那么这个设计就是从操作 ...

  5. linux利用screen进行shell下的屏幕协作

    我们都知道linux是支持多终端并行处理的 但是某些时候我们可能有比较特殊的需求需要两个人同时处理一个终端,screen 正好能满足这个要求 首先需要安装screen软件: debian和ubuntu ...

  6. Hadoop分布式平台搭建

    环境:CentOS 7.4 (1708  DVD) 工具:MobaXterm 一. 安装 1. 将hadoop安装包上传到/usr/local目录下,将其解压并重命名. 2. 配置hadoop的环境变 ...

  7. web自动化 模拟鼠标、键盘操作

    一.鼠标操作 1.1鼠标的悬停操作,move_to_element from selenium import webdriver from selenium.webdriver.common.acti ...

  8. React Native两种加载图片的方式

    1 加载网络图片 通过uri就可以加载网络图片 <Image source={{uri:'http://facebook.github.io/react/img/logo_og.png'}} s ...

  9. 一套标准的ASP.NET Core容器化应用日志收集分析方案

    讲故事 关注我公众号的朋友,应该知道我写了一些云原生应用收集和分析相关的文章,其中内容大多聚焦某个具体的组件: 超级有用的TraceId,快点用起来吧! 如何利用NLog输出结构化日志,并在Kiban ...

  10. 迭代器原理gif