java 并发编程
Timer类负责管理延迟任务以及周期任务,然而Timer存在一些缺陷。
Timer类在执行任务时候只会创建一个线程,如果某个任务的执行时间过长,那么将破坏其他TimerTask的定时精确性。
Timer的另一个问题是,如果TimerTask抛出一个未检查的异常,那么Timer将表现出糟糕的行为。Timer线程并不捕获异常,因此当TimerTask抛出未检查的异常时将终止定时线程。这种情况下,Timer也不会回复线程的执行,而是会错误的认为整个Timer都被取消了。故,已经被调度但尚未执行的TimerTask将不会执行,新的任务也不能被调度,这个问题被成为线程泄露。
public class OutOfTime {
public static void main(String[] args) throws InterruptedException {
Timer timer=new Timer();
timer.schedule(new ThrowTask(), 1);
Thread.currentThread().sleep(1);
timer.schedule(new ThrowTask(), 1);
Thread.currentThread().sleep(5);
}
static class ThrowTask extends TimerTask{
@Override
public void run() {
throw new RuntimeException();
}
}
}
Java中检查的异常与未检查的异常
public class ExceptionTypeTest {
public void doSomething()throws ArithmeticException{
System.out.println();
}
public static void main(String args[]){
ExceptionTypeTest ett = new ExceptionTypeTest();
ett.doSomething();
}
}
问题1:上面的程序能否编译通过?并说明理由。
解答:能编译通过。分析:按照一般常理,定义doSomething方法是定义了ArithmeticException异常,在main方法里 里面调用了该方法。那么应当继续抛出或者捕获一下。但是ArithmeticException异常是继承RuntimeException运行时异常。 java里面异常分为两大类:checked exception(检查异常)和unchecked exception(未检
查异常),对于未检查异常也叫RuntimeException(运行时异常),对于运行时异常,java编译器不要求你一定要把它捕获或者一定要继续抛出,但是对checked exception(检查异常)要求你必须要在方法里面或者捕获或者继续抛出.
问题2:上面的程序将ArithmeticException改为IOException能否编译通过?并说明理由。
解答:不能编译通过。分析:IOException extends Exception 是属于checked exception ,必须进行处理,或者必须捕获或者必须抛出
总结:
java中异常分为两类: checked exception(检查异常)和unchecked exception(未检查异常),
对于未检查异常也叫RuntimeException(运行时异常).
对未检查的异常(unchecked exception )的几种处理方式:
1、捕获
2、继续抛出
3、不处理
对检查的异常(checked exception,除了RuntimeException,其他的异常都是checked exception )的几种处理方式:
1、继续抛出,消极的方法,一直可以抛到java虚拟机来处理
2、用try...catch捕获
注意,对于检查的异常必须处理,或者必须捕获或者必须抛出