理解线程状态,答疑wait与sleep是否占用cpu资源的问题,再来个小demo 您所在的位置:网站首页 信号100资源 理解线程状态,答疑wait与sleep是否占用cpu资源的问题,再来个小demo

理解线程状态,答疑wait与sleep是否占用cpu资源的问题,再来个小demo

2023-11-04 10:46| 来源: 网络整理| 查看: 265

线程的生命周期及五种基本状态

关于Java中线程的生命周期,首先看一下下面这张较为经典的图:

在这里插入图片描述

上图中基本上囊括了Java中多线程各重要知识点。掌握了上图中的各知识点,Java中的多线程也就基本上掌握了。主要包括:

Java线程具有五中基本状态

新建状态(New):当线程对象对创建后,即进入了新建状态,如:Thread t = new MyThread();

就绪状态(Runnable):当调用线程对象的start()方法(t.start();),线程即进入就绪状态。处于就绪状态的线程,只是说明此线程已经做好了准备,随时等待CPU调度执行,并不是说执行了t.start()此线程立即就会执行;

运行状态(Running):当CPU开始调度处于就绪状态的线程时,此时线程才得以真正执行,即进入到运行状态。注:就 绪状态是进入到运行状态的唯一入口,也就是说,线程要想进入运行状态执行,首先必须处于就绪状态中;

阻塞状态(Blocked):处于运行状态中的线程由于某种原因,暂时放弃对CPU的使用权,停止执行,此时进入阻塞状态,直到其进入到就绪状态,才 有机会再次被CPU调用以进入到运行状态。根据阻塞产生的原因不同,阻塞状态又可以分为三种:

1.等待阻塞:运行状态中的线程执行wait()方法,使本线程进入到等待阻塞状态;

2.同步阻塞 – 线程在获取synchronized同步锁失败(因为锁被其它线程所占用),它会进入同步阻塞状态;

3.其他阻塞 – 通过调用线程的sleep()或join()或发出了I/O请求时,线程会进入到阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。

死亡状态(Dead):线程执行完了或者因异常退出了run()方法,该线程结束生命周期。

从图中可以看出,只有runnable到running时才会占用cpu时间片,其他都会出让cpu时间片。 线程的资源有不少,但应该包含CPU资源和锁资源这两类。 sleep(long mills):让出CPU资源,但是不会释放锁资源。 wait():让出CPU资源和锁资源。 锁是用来线程同步的,sleep(long mills)虽然让出了CPU,但是不会让出锁,其他线程可以利用CPU时间片了,但如果其他线程要获取sleep(long mills)拥有的锁才能执行,则会因为无法获取锁而不能执行,继续等待。 但是那些没有和sleep(long mills)竞争锁的线程,一旦得到CPU时间片即可运行了。

转个demo学习下notify与wait的使用

假设有一个公共的容量有限的池子,有两种人,一种是生产者,另一种是消费者。需要满足如下条件:

1、生产者产生资源往池子里添加,前提是池子没有满,如果池子满了,则生产者暂停生产,直到自己的生成能放下池子。

2、消费者消耗池子里的资源,前提是池子的资源不为空,否则消费者暂停消耗,进入等待直到池子里有资源数满足自己的需求。

- 仓库类

import java.util.LinkedList; /** * 生产者和消费者的问题 * wait、notify/notifyAll() 实现 */ public class Storage1 implements AbstractStorage { //仓库最大容量 private final int MAX_SIZE = 100; //仓库存储的载体 private LinkedList list = new LinkedList(); //生产产品 public void produce(int num){ //同步 synchronized (list){ //仓库剩余的容量不足以存放即将要生产的数量,暂停生产 while(list.size()+num > MAX_SIZE){ System.out.println("【要生产的产品数量】:" + num + "\t【库存量】:" + list.size() + "\t暂时不能执行生产任务!"); try { //条件不满足,生产阻塞 list.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } for(int i=0;i list.size()){ System.out.println("【要消费的产品数量】:" + num + "\t【库存量】:" + list.size() + "\t暂时不能执行生产任务!"); try { list.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } //消费条件满足,开始消费 for(int i=0;i


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有