草庐IT

Try-Finally

全部标签

java - 对于基于 I/O 的流,我应该在 flatMap 中使用 try-with-resource 吗?

AStream是一个AutoCloseable,如果基于I/O,应该在try-with-resourceblock中使用。通过flatMap()插入的基于I/O的中间流怎么样?示例:try(varfoos=foos()){returnfoos.flatMap(Foo::bars).toArray(Bar[]::new);}对比try(varfoos=foos()){returnfoos.flatMap(foo->{try(varbars=foo.bars()){returnbars;}}).toArray(Bar[]::new);}flatMap()文档说:Eachmappedstre

JAVA + try catch(FileNotFoundException e) 进入 catch(Exception e)?

我有一些命令可以在磁盘上创建一个文件。因为必须在其中创建文件的文件夹是动态的,所以我有一个问题(FileNotFoundExceptione)。在同一个tryblock中,我已经有了一个catch(Exceptione)block。出于某种原因,当我运行我的代码并且该文件夹尚不存在时,将使用catch(Exceptione)block,而不是FileNotFoundExceptionblock。虽然调试器很清楚(至少对我而言),但显示了FileNotFoundException:java.io.FileNotFoundException:c:\mydata\2F8890C2-13B9-

java - 如果 catch block 或 finally block 有一些异常会发生什么?

这个问题在这里已经有了答案:Exceptionthrownincatchandfinallyclause(12个答案)关闭8年前。在异常处理中,如果catchblock或者finallyblock出现Exception会怎样?

java - 如何在 finally block 中调用 System.exit(0) 后运行代码

我有三个类,比如alpha、beta、gamma,这三个类中的每一个都有一个main方法。alpha和beta类在它们的main方法中都有一个try...catch...finallyblock,如下所示:publicclassalpha{publicstaticvoidmain(String[]args){try{Dosomething;}catch(Exceptionex){ex.printStackTrace();}finally{System.exit(0);}}}publicclassbeta{publicstaticvoidmain(String[]args){try{Do

java - 如何检索 'try' block 中被抑制的异常?

从Java7开始,我们可以使用try-with-resources语句:staticStringreadFirstLineFromFile(Stringpath)throwsIOException{try(BufferedReaderbr=newBufferedReader(newFileReader(path))){returnbr.readLine();}}如果br.readLine()和br.close()都抛出异常,readFirstLineFromFile将throwtryblock的异常(br.readLine()的异常),以及隐式finallyblock的try-with

java - 将 Realm 与 try-with-resources 一起使用是一种好习惯吗?

很多地方建议在Activity的onCreate方法中调用Realm.getDefaultInstance(),并调用close在onDestroy中的Realm实例上(或在presenter的相应方法中)。但是,对我来说,使用Java的try-with-resources结构会更干净:try(finalRealmrealm=Realm.getDefaultInstance()){//dostuff}为什么要清洁?IMO更容易管理realm实例的狭窄范围。在生命周期的某个时刻获取实例并在另一个时刻关闭它,这让我想起了过去使用C++的日子,那时我们不得不担心在正确的时刻调用delete。

java - Try/Catch 内部或外部函数

我有一个关于使用try/catch的最佳实践的非常基本的问题。我有一个像这样的简单函数(DAO):publicvoidaddVehicle(Vehiclevehicle){em.getTransaction().begin();em.persist(vehicle);em.getTransaction().commit();}并在网络服务中使用DAO功能:@WebMethod(operationName="addVehicle")publicvoidaddVehicle(Vehiclevehicle){try{vehicleDAO.addVehicle(vehicle);System.

java - 像这样嵌套 try/finally 子句安全吗?

由于这是关于try/finally子句行为的学术问题,因此我尝试使用一个非常通用的示例。像这样嵌套try/finally子句有什么危险吗?openDatabaseConnection();try{//Methodsunrelatedtocursor//...Stringcursor_id=openCursor();try{useCursor(cursor_id);}finally{closeCursor(cursor_id);}//Methodsunrelatedtocursor//...}catch(Exceptione){genericLogError();}finally{clo

java - try/catch/finally 的惊人输出?

这个问题在这里已经有了答案:Behaviourofreturnstatementincatchandfinally(8个答案)关闭8年前。我运行这段代码:publicstaticvoidmain(String[]args){System.out.println(catcher());}privatestaticintcatcher(){try{System.out.println("TRY");thrower();return1;}catch(Exceptione){System.out.println("CATCH");return2;}finally{System.out.prin

try-with-resources 中的 Java 准备语句不起作用

这个问题在这里已经有了答案:HowshouldIusetry-with-resourceswithJDBC?(5个答案)关闭8年前。昨天,Stack上的多人推荐使用try-with-resources。我现在正在为我的所有数据库操作执行此操作。今天想把Statement改成PreparedStatement,让查询更安全。但是,当我尝试在try-with-resources中使用准备好的语句时,我不断收到诸如“预期标识符”或“;”之类的错误或')'。我做错了什么?或者这不可能吗?这是我的代码:try(Connectionconn=DriverManager.getConnection(