线程

什么是线程

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

为什么要使用多线程

  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. 模拟鼠标操作(ActionChains)(转 侵删)

    在日常的测试中,经常会遇到需要鼠标去操作的一些事情,比如说悬浮菜单.拖动验证码等,这一节我们来学习如何使用webdriver模拟鼠标的操作 首页模拟鼠标的操作要首先引入ActionChains的包 f ...

  2. parted命令采用gpt分区过程

    Gpt无分区限制,故只有主分区,无扩展分区和逻辑分区.分区直接按容量算,不按柱面算. 查看分区:parted -l 将分区表类型转换为gpt.: 主要命令mklabel gpt 对sdc盘分区: [r ...

  3. HashMap 链表插入方式 → 头插为何改成尾插 ?

    开心一刻 一天,楼主在路上碰到了一个很久没见的朋友,找了个餐馆,坐下聊了起来 楼主:在哪上班了 ? 朋友:火葬场啊 楼主:在那上班,一个月多少钱啊 ? 朋友:两万多啊 楼主(不可思议):多少 ? 朋友 ...

  4. 我要进大厂之大数据Hadoop HDFS知识点(2)

    01 我们一起学大数据 老刘继续分享出Hadoop中的HDFS模块的一些高级知识点,也算是对今天复习的HDFS内容进行一次总结,希望能够给想学大数据的同学一点帮助,也希望能够得到大佬们的批评和指点! ...

  5. tp5 上传图片(自定义图片路径)

    控制器调用 /** * [goods_addimg 图片上传] * @return [type] [description] */ public function addimg(){ if (requ ...

  6. 他凭借这70份PDF,3170页文件,成功斩获了含BATJ所有的offer

    前言 最近我一直在面试高级工程师,不管初级,高级,程序员,我想面试前,大家刷题一定是是少不了吧. 我也一样,我在网上找了很多面试题来看,最近又赶上跳槽的高峰期,好多粉丝,都问我要有没有最新面试题,索性 ...

  7. node.js报错:Cannot find module 'xxx'的解决办法

    从别处拷贝一份node.js项目,如图 控制台启动 nodemon index.js 后报错:Cannot find module xxx.删除node_modules,在启动时仍提示Cannot f ...

  8. spring中的事务传播机制

    1.事务的实现思想 在spring中要想某个方法具有事务,只要在方法前加一个@Transactional注解.然后spring就会利用aop思想,在这个方法执行前开启事务, 在方法执行后选择提交事务或 ...

  9. [poi使用]使用excel模版导出excel

    ​ Apache POI是基于Office Open XML标准(OOXML)和Microsoft的OLE 2复合文档格式(OLE2)处理各种文件格式的开源项目.简而言之,您可以使用Java读写MS ...

  10. docker中启动容器提示端口被占用

    docker中启动容器提示端口被占用,但是 docker ps -a 查不到信息 1.查询端口被占用的id netstat -ntpl |grep 3306 2.杀掉该id kill -9 如果kil ...