Java面试问题之四十四
程序员文章站
2022-07-12 21:34:12
...
请写出下面程序的运行结果,并分析运行的过程。
问题分析:当线程A处于阻塞状态时,如果线程B调用线程A的interrupt()方法,那么线程A会接受到一个interruptedException,并退出阻塞状态,开始进行异常处理。上面的程序,Machine线程不断把变量a的值加1,如果变量a的值大于3,就会进入Machine对象的等待池,定时器从Machine线程转到阻塞状态开始计时。如果Machine线程在等待池中的时间超过了3秒,定时器就会调用Machine线程的interrupt()方法,使Machine线程中断阻塞并开始执行异常处理代码块。
所以,上述程序输出的结果应该是:
a=1
a=2
a=3
a=4
Thread-1 has waited for 3 seconds
Thread-1 is interrupted
知识扩展:当一个阻塞的线程抛出InterruptedException异常时,应该根据实际情况来决定如何处理它。如果是由于潜在的程序错误导致这种异常,那么可以在catch代码块中把它包装为运行时错误再将其抛出;如果是由于受到预期的干扰而抛出的异常,那么可以在catch代码块中提供相应的处理逻辑。
import java.util.*; public class MachineInterruptedException extends Thread { private int a = 0; private Timer timer = new Timer(true); public synchronized void reset(){ a=0; } public void run() { while(true) { synchronized(this){ while(a>3) { final Thread thread = Thread.currentThread(); timer.schedule(new TimerTask(){ public void run() { System.out.println(thread.getName()+" has waited for 3 seconds"); thread.interrupt(); } },3000); try { this.wait(); }catch(InterruptedException e){ System.out.println(thread.getName()+" is interrupted"); return; } } a++; System.out.println("a="+a); } } } public static void main(String[] args) throws Exception { MachineInterruptedException machine = new MachineInterruptedException(); machine.start(); } }
问题分析:当线程A处于阻塞状态时,如果线程B调用线程A的interrupt()方法,那么线程A会接受到一个interruptedException,并退出阻塞状态,开始进行异常处理。上面的程序,Machine线程不断把变量a的值加1,如果变量a的值大于3,就会进入Machine对象的等待池,定时器从Machine线程转到阻塞状态开始计时。如果Machine线程在等待池中的时间超过了3秒,定时器就会调用Machine线程的interrupt()方法,使Machine线程中断阻塞并开始执行异常处理代码块。
所以,上述程序输出的结果应该是:
a=1
a=2
a=3
a=4
Thread-1 has waited for 3 seconds
Thread-1 is interrupted
知识扩展:当一个阻塞的线程抛出InterruptedException异常时,应该根据实际情况来决定如何处理它。如果是由于潜在的程序错误导致这种异常,那么可以在catch代码块中把它包装为运行时错误再将其抛出;如果是由于受到预期的干扰而抛出的异常,那么可以在catch代码块中提供相应的处理逻辑。