这篇小编想分享一下关于我们常见的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 执行以下,建议多执行几遍,有时候可能每次执行的结果都不一样。其次建议大家把注释的代码也执行以下,有利于大家理解线程调度,主线程和子线程。需要注意的是main主线程,这个需要大家好好理解以下。
总结:
多线程我们开始理解的时候可能很简单,动手做的时候可能感觉很模糊,不清楚线程是个怎样的概念,这个时候需要多执行两遍你的代码,然后修改你的代码,继续执行,你会返现一些不一样的东西。总之线程是个很有意思的东西,大家可以深入研究一下!我在这儿算是抛砖引玉吧!
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主线程,这个需要大家好好理解以下。
总结:
多线程我们开始理解的时候可能很简单,动手做的时候可能感觉很模糊,不清楚线程是个怎样的概念,这个时候需要多执行两遍你的代码,然后修改你的代码,继续执行,你会返现一些不一样的东西。总之线程是个很有意思的东西,大家可以深入研究一下!我在这儿算是抛砖引玉吧!