个人认为一般是以下两种情况才应该用到try-catch进行异常处理,其他情况的异常直接在方法抛出(checked exception),或者不做处理(unchecked exception):
1、异常发生后程序需要继续。
2、模块入口处隐藏本模块的异常细节,封装定制的异常信息。比如WebService的接口方法、Controller或者Action等web直接访问的方法
要非常注意的是,经过try-catch进行异常处理之后,异常信息,如堆栈信息,不应有所丢失,如果catch到的异常不能完整的重新抛出,比如程序需要继续运行、模块入口对错误信息进行了定制等等,应该将完整的错误信息记录到log。
实际开发中可能会遇到方法不适宜直接抛出异常的情况,我觉得如果有这种情况,可能需要考虑一下软件的设计是否合理,或者权宜之计可以用RuntimeException封装一下。
另外有些情况,在异常产生后,有一些后续的动作必须进行,比如关闭流,这时应该用try-finally。