我们一般在底层写方法时,如果方法显示throws异常,那么在调用时,也需要将这个异常throws出来,例如
public RetOps<T> assertCode(Integer expect, Function<? super R<T>, ? extends Exception> func)
throws Exception {}
调用时
@Test
public void testR() throws Exception {
R<Integer> result = new R<>();
result.setCode(2001);
result.setData(1024);
new RetOps<>(result).assertCode(200, i -> new RuntimeException("error " + i.getCode()))
.assertDataNotNull(r -> new IllegalStateException("oops!")).useData(System.out::println);
}
如果调用时不显示throws出异常,编译器会报出错误,如下图
泛型类型声明异常
public RetOps assertCode(Integer expect, Function<? super R, ? extends Ex> func)
throws Ex {}
调用方法时,不需要再throws Ex了,这种对调用者更友好,如图
解释说明
在第一个方法中,使用了泛型类型 来定义异常类型,因此在调用该方法时不需要显式声明throws Ex。这是因为编译器会根据实际情况推断出可能抛出的异常类型,并进行相应的处理。
而在第二个方法中,直接使用了Exception作为返回类型,因此在调用该方法时需要显式声明throws Exception,表明该方法可能会抛出Exception或其子类的异常。
通过泛型定义异常类型可以使代码更加灵活,同时也能提供更好的类型安全性。
© 版权声明
本站所有资源来自于网络,仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您(转载者)自己承担!
如有侵犯您的版权,请及时联系3500663466#qq.com(#换@),我们将第一时间删除本站数据。
如有侵犯您的版权,请及时联系3500663466#qq.com(#换@),我们将第一时间删除本站数据。
THE END
暂无评论内容