欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Java面试问题之四十四

程序员文章站 2022-07-12 21:34:12
...
请写出下面程序的运行结果,并分析运行的过程。

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