对于诸如Spring MVC之类的库来说,什么是有意义的,它需要足够开放才能适合各种不同的用例,但在编写特定的应用程序时,遵循您的想法并不一定有意义。这是其中一种情况。
如果您要引用的类(例如Controller
接口)作为方法签名,例如
handleRequest(HttpServletRequest request, HttpServletResponse response)
throws Exception
这很可能是因为,从调用您的Controller的Spring类(例如DispatcherServlet
)的角度来看,它们并不关心您的代码调用的是哪种类型的Exception- 库代码(例如)DispatcherServlet
仅需要知道此类可能抛出Exception因此可以在一般情况下处理Exception。
换句话说,DispatcherServlet
不需要知道您的控制器可能抛出哪种特定类型的Exception- 它将把它们中的任何一个都视为“错误”。这就是方法签名为的原因throws Exception
。
现在,API作者可以使签名使用自定义的异常类型作为SpringMvcException
,但这只会迫使您处理方法中所有已检查的异常类型handleRequest
并将它们包装起来,这是乏味的工作样板代码。因此,由于Spring的几乎所有功能都是为了使您尽可能轻松,轻便地与之集成而设计的,因此让他们仅指定interface方法就更容易了throws Exception
。