多线程--sleep、yield对比

本文探讨了Java中多线程的sleep和yield方法的区别。sleep方法使线程进入阻塞状态,指定时间内无法执行,而yield方法则让当前线程变为就绪状态,可能在同优先级或更高优先级的线程中重新获得执行机会。通过示例代码演示了这两个方法的使用,强调理解多线程调度的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这篇小编想分享一下关于我们常见的sleep、yield方法的有什么不同。
1、sleep:线程睡眠,如果我们需要让当前正在执行的线程暂停一段时间,并进入阻塞状态,就可以通过调用sleep方法来实现。在线程进入阻塞状态后,再sleep 这段时间内,该线程不会获得执行的机会,及时系统中没有运行的线程,处于sleep中的线程也不会执行。
主要由两种重载方法:
(1)static void sleep(long millis):让当前线程暂停millis毫秒并进入阻塞状态。(ps 常用)
(2)static void sleep(long millis,int nanos):让当前正在执行的线程暂停millis毫秒加nanos毫微秒。(ps 不常用)
demo:
public class TestSleep {
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        for(int i=0;i<10;i++){
            System.out.println("当前时间:"+new Date()+"  "+Thread.currentThread().getName()+"   "+i);
            
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }
}


2.yield线程让步,是一个Thread类提供的静态方法,可以让当前正在执行的线程暂停,但他不会阻塞该线程,它只是让该线程转入就绪状态,当系统的线程调度器重新调度时,还可以被调度出来重新执行。此外,当某个线程调用yield方法暂停时,只有优先级与当前线程相同,或者优先级更高的线程才能获得执行的机会。
线程在调度的过程中需要考虑优先级,其次是谁得到资源谁执行。
demo:
public class YieldTest extends Thread {
    public YieldTest(){
        
    }
    public YieldTest(String name){
        super(name);
    }
    public void run(){
        for(int i=0;i<50;i++){
            System.out.println(getName()+" "+i);
            //System.out.println(Thread.currentThread().getName()+" "+i);
            if(i == 20){
                Thread.yield();
            }
        }
        
    }
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        YieldTest ty1= new YieldTest("高级");
        ty1.setPriority(Thread.MAX_PRIORITY);
        ty1.start();
        
        YieldTest ty2 =new YieldTest("低级");
        ty2.setPriority(MIN_PRIORITY);
        ty2.start();
        
        /*for(int i=0;i<10;i++){
            YieldTest ty2 =new YieldTest("低级");
            ty2.setPriority(MIN_PRIORITY);
            ty2.start();
            System.out.println(Thread.currentThread().getName()+" "+i);
        }*/
        
    }
} 


解析:大家可以按照提供的demo 执行以下,建议多执行几遍,有时候可能每次执行的结果都不一样。其次建议大家把注释的代码也执行以下,有利于大家理解线程调度,主线程和子线程。需要注意的是main主线程,这个需要大家好好理解以下。

总结:
         多线程我们开始理解的时候可能很简单,动手做的时候可能感觉很模糊,不清楚线程是个怎样的概念,这个时候需要多执行两遍你的代码,然后修改你的代码,继续执行,你会返现一些不一样的东西。总之线程是个很有意思的东西,大家可以深入研究一下!我在这儿算是抛砖引玉吧!
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值