专栏首页行者常至005.多线程-线程的生命周期

005.多线程-线程的生命周期



package cn.qbz.thread;

public class ThreadLifeTest {
    public static void main(String[] args) {

        Thread thread1 = new Thread(new Runnable() {
            public void run() {
                System.out.println("4.阻塞状态......");
                for (int i = 0; i < 2; i++) {
                    System.out.println("我是来阻塞的,哈哈哈......");
                }
            }
        });

        //1.新建状态 线程未被启动
        ThreadTest thread2 = new ThreadTest(thread1);
        System.out.println("1.新建状态......");
        //2.就绪状态 线程已经被启动,正在等待被分配给CPU时间片
        thread2.start();
        System.out.println("2.就绪状态......");
    }
}

class ThreadTest extends Thread {
    private Thread thread;

    public ThreadTest(Thread thread) {
        this.thread = thread;
    }

    @Override
    public void run() {
        for (int i = 0; i < 5; i++) {
            // 线程获得CPU资源正在执行任务(run()方法),
            // 此时除非此线程自动放弃CPU资源或者有优先级更高的线程进入,
            // 线程将一直运行到结束
            System.out.println("3.运行状态......");

            if (i == 2) {
                try {
                    //4.阻塞状态,等thread线程执行结束或者阻塞后,
                    //            当前线程才可以继续执行
                    thread.start();
                    thread.join();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }

        System.out.println("5.即将死亡......");
    }


}

新建状态: 当创建Thread类的一个实例(对象)时,此线程进入新建状态(未被启动)。 如:ThreadTest thread2 = new ThreadTest(thread1);


就绪状态: 线程已经被启动,正在等待被分配给CPU时间片, 也就是说此时线程正在就绪队列中排队等候得到CPU资源。 如:thread.start();


运行状态: 线程获得CPU资源正在执行任务(run()方法), 此时除非此线程自动放弃CPU资源或者有优先级更高的线程进入, 线程将一直运行到结束。


死亡状态: 当线程执行完毕或被其它线程杀死,线程就进入死亡状态, 这时线程不会再进入就绪状态等待执行。

自然终止:正常运行run()方法后终止 异常终止:调用stop()等方法让一个线程终止运行


阻塞状态: 由于某种原因导致正在运行的线程让出CPU并暂停自己的执行,即进入堵塞状态。

等待阻塞:wait() 同步阻塞:获取同步锁失败 其他阻塞:sleep()、join()

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 003.多线程-主线程、守护线程、用户线程的区别

    守护线程: 主要是指 在进程中,为主线程提供一种通用服务的线程。 比如 gc线程 因为,主线程一旦结束或者销毁, 守护线程没有了守护对象, 也将同步进...

    qubianzhong
  • 001.多线程-进程与线程的区别

    什么是进程?顾名思义,就是进行中的程序,也就是运行中的程序。我们打开电脑的任务管理器可以看到:

    qubianzhong
  • 016.多线程-线程池的四种创建方式

    版权声明:本文为博主原创文章,允许转载,请标明出处。 https://blog.csdn.net/qwdafedv/article/deta...

    qubianzhong
  • java内存模型,多线程三大特性,volatile,Threalocal,线程池

    事物有原子性,这个概念大概都清楚,即一个操作或多个操作要么执行的过程中不被任何因素打断,要么不执行。

    斯文的程序
  • Executor的使用

    在上一篇我们简单的介绍了线程池的使用,虽然线程池比我们直接使用原始的线程类更加方便,但在创建线程池对象时对参数的设置是需要开发人员精心考量的,否则线程池并不会实...

    吉林乌拉
  • Java线程池详解

    线程能够充分合理地协调利用CPU、内存、I/O等系统资源,但是线程的创建需要开辟虚拟机栈、本地方法栈、程序计数器等线程私有空间,在线程销毁时需要回收这些系统资源...

    公众号 IT老哥
  • Java中的线程组

    在开发多线程时,可以用ThreadGroup关键字创建一个线程组来方便管理一系列的子线程,线程组可以统一的设置线程的某些属性。

    吉林乌拉
  • 全网最火Java面试题

    回复:Java全套教程,即可获取Java基础、Java web、Java EE、spring boot等完整学习视频。

    公众号 IT老哥
  • 线程池ThreadPoolExecutor源码分析

    多线程是我们日常工作中很少能接触到的技术,但是面试的时候100%会被问到,万一工作中用到了基本不会,本篇咱们就来深入分析线程池的实现类ThreadPoolExe...

    公众号 IT老哥
  • 【Java多线程-7】阅尽Java千般锁

    根据对同步资源处理策略不同,锁在宏观上分为乐观锁与悲观锁,这只是概念上的一种称呼,Java中并没有具体的实现类叫做乐观锁或者悲观锁。

    云深i不知处

扫码关注云+社区

领取腾讯云代金券