概念介绍
要让当前正被 CPU 执行的线程让度出 CPU,其实有两种方式。一种是被动的,比如当前线程需要进行 IO 操作;但是这里讨论的是一种主动让度的方式。而要达到主动的让度一般就两种方式,一种是 sleep 方法,一种是 yield 方法。(wait 方法是一种条件等待的方式,需要别的线程去唤醒,但是 wait 带时间的方法,不需要条件,也是一种主动让度的方式)。
让度方法介绍
sleep 方法
它是声明在 Thread 类中的一个静态方法,入参为一个毫秒单位的时间值。使用也非常简单:
public static void main(String[] args) {
System.out.println("main start");
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("main end");
}
可以看到 sleep 方法有一个中断异常,因此当线程在 sleep 时,别的线程调用了该线程的 interrupt 方法后,该线程会响应这个中断,抛出异常。
还有两点需要注意,sleep 方法和 wait 方法刚好相反,sleep 时不会释放锁,因此当前线程会一直占有锁。还有一点是如果传入的入参为负数则会抛出 IllegalArgumentException 异常。
yield 方法
它也是声明在 Thread 类中的一个静态方法,入参为空;当一个线程调用该方法时,就是在告诉操作系统的线程调度器,请求让度出自己占用的 CPU ,但是线程调度器是可以忽略这个请求的,因此有时候并不一定生效。
public static void main(String[] args) {
Thread t1 = new Thread(() -> {
for (int i = 0 ; i < 10 ;i ++) {
if (i == 0) {
System.out.println("t"+i+" yield");
Thread.yield();
}
System.out.println("t"+i+" end");
}
});
Thread t2 = new Thread(() -> {
for (int i = 0 ; i < 10 ;i ++) {
if (i == 0) {
System.out.println("t"+i+" yield");
Thread.yield();
}
System.out.println("t"+i+" end");
}
});
t1.start();
t2.start();
System.out.println("main end");
}
以上代码多次尝试能看到 yield 方法执行的效果,有时候能生效,有时候是不生效的。这个方法在实际工作中是不用的,所以只做一个了解就行。
总结
1、sleep 方法会响应中断,在等待时被中断会抛出异常;
2、sleep 方法不会释放锁,因此执行的时候当前线程还是占用锁的;
3、yield 方法只是请求线程调度器,出让自己的 CPU 执行时间,但是不一定成功;
4、yield 方法在实际工作中是不使用的,了解就好。
网友评论