Java线程的几种状态

Java 线程的几种状态

线程状态图:
在这里插入图片描述

  • NEW:新建状态,还未开始工作,需要用start()方法启动线程,加入到线程就绪队列
  • RUNNABLE:正在工作或是即将开始工作,即将开始工作状态需要CPU调度才能进入到正在工作状态
  • BLOCKED(阻塞状态):等待获取锁
  • WAITING:永远的等待,一直等,等到有人来唤醒它
  • TIME_WAITING:有限的等待,设置了等待时长,时长一到就会自动唤醒
  • TERMINATED:工作完成

yield()方法
《JAVA并发编程之美》书中是这么描述的:
“当一个线程调用yield()方法时,实际就是在暗示线程调度器当前线程请求让出自己的cpu使用,但是线程调度器可以无条件忽略这个暗示。操作系统是为每一个线程分配一个时间片来占有cpu,正常情况下当一个线程把时间片使用完之后线程调度器才会进行下一轮的线程调度,而当一个线程调用了yield()时,是在告诉线程调度器自己占有的时间片还没有使用完的部分自己不想使用了,这暗示线程调度器现在就可以进行下一轮的线程调度;当一个线程调用yield()方法时,当前线程会让出cpu的使用权,然后处于就绪状态,线程调度器会从线程就绪队列中获取一个线程优先级最高的线程,当然也可能会调度到刚刚调用yield()的线程来获取cpu的执行权”
总的来说就是,当一个线程调用了yield()方法后,线程调度器可以释放这个线程对cpu的执行权让其处于就绪状态,但线程调度器可以无条件忽视这个线程的暗示让这个线程一直占有着cpu。
由于这个具有不确定性,线程调度器是否要释放当前线程的CPU执行权,所以使用也不是很广泛,但确实能让别的线程执行多于该线程
例如以下代码:

Thread t1 = new Thread(new Runnable() {
    @Override
    public void run() {
       while (true) {
            System.out.println("yield了的线程");
            Thread.yield();
       }
   }
}, "t1");
t1.start();
Thread t2 = new Thread(new Runnable() {
    @Override
    public void run() {
        while (true) {
            System.out.println("主线程");
       }
   }
}, "t2");
t2.start();

会发现打印“yield的线程”的次数远低于打印“主线程”。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值