日期:2014-05-20  浏览次数:20619 次

Java面试问题之四十四
请写出下面程序的运行结果,并分析运行的过程。

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代码块中提供相应的处理逻辑。