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捕获 
        注意,对于检查的异常必须处理,或者必须捕获或者必须抛出