jjzjj

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

java - try/finally without catch with return 语句?

这个问题在这里已经有了答案:Multiplereturns:Whichonesetsthefinalreturnvalue?(7个答案)关闭6年前。为什么下面代码的结果是3,为什么finallyget终止并退出方法,即使编译器先检查try,为什么try中的return没有终止方法?publicintreturnVal(){try{return2;}finally{return3;}}

java - block 捕获中的丢失异常

我运行这段代码:publicclassUser{publicstaticvoidmain(Stringargs[]){intarray[]=newint[10];inti=1;try{System.out.println("try:"+i++);System.out.println(array[10]);System.out.println("try");}catch(Exceptione){System.out.println("catch:"+i++);System.out.println(array[10]);System.out.println("catch");}finall

java - 调试时不关闭数据库连接有问题吗?

我有一个Java应用程序,它在开始时打开与数据库的连接,并在结束时关闭它。但是,程序并不总是完成,因为抛出异常或者我正在调试它并在中途停止。这会导致打开的连接堆积并减慢数据库速度,还是会自动清理? 最佳答案 数据库连接由数据库拥有和管理,该类只允许您访问该数据库资源。如果您不关闭连接,则Java类可能会被垃圾回收,但数据库可能无法判断连接不再被使用,这可能会导致数据库资源被浪费(直到数据库端超时)甚至泄漏。因此,当您使用完Connection后,您应该确定通过调用它的close()显式关闭它方法。这将允许垃圾收集器尽早重新收集内存,

java - “finally” block 对 “try” block 的返回值的影响

Thisquestionalreadyhasanswershere:Whydoeschangingthereturnedvariableinafinallyblocknotchangethereturnvalue?(7个答案)7年前关闭。我正在阅读此question,并且得到了以下代码片段:publicvoidtestFinally(){System.out.println(setOne().toString());}protectedStringBuildersetOne(){StringBuilderbuilder=newStringBuilder();try{builder.ap

java - 我们如何将 try finally 用于 Lock.lock 和 Lock.unlock

考虑以下代码。为了防止IndexOutOfBoundsException打电话时listIterator,我们使用读取器锁来检索基于索引的iteartor,并在对stockCodes进行写操作时使用写入器锁.请注意,我们没有使用任何锁定机制来使用listIterator进行迭代,因为它来自CopyOnWriteArrayList.不需要锁定,因为ConcurrentModificationException不应被抛出。//stockCodesReaderLockisreaderlockfromjava.util.concurrent.locks.ReadWriteLock//stock

java - 在 finally block 中设置 reference = null?

我的一位同事在finallyblock中设置了对null的引用。我认为这是无稽之谈。publicSomethinggetSomething(){JDBCConnectionjdbc=null;try{jdbc=JDBCManager.getConnection(JDBCTypes.MYSQL);...}finally{JDBCManager.free(jdbc);jdbc=null;//你怎么看? 最佳答案 你是对的,jdbc是一个局部变量,所以当getSomething()方法返回时jdbc将超出范围并符合条件垃圾收集实际上与将其

最终好奇的Java未初始化变量

当我遇到一段有趣的代码时,我正试图为我正在帮助的替代开源JVM(Avian)提出晦涩的测试用例,令我惊讶的是它没有编译:publicclassTest{publicstaticinttest1(){inta;try{a=1;returna;//thisisfine}finally{returna;//uninitializedvalueerrorhere}}publicstaticvoidmain(String[]args){inta=test1();}}最明显的代码路径(我看到的唯一一个)是执行a=1,“尝试”返回a(第一次),然后执行finally,实际上返回一种。然而,javac

java - 为什么 javac 不优化空的 try-finally block ?

我写了一个类classtest1{voidfoo(){}}还有一个有很多try和finally语句什么都不做的类:classtest2{voidfoo(){try{}finally{}try{}finally{}try{}finally{}try{}finally{}try{}finally{}}}使用javac(sun-jdk-1.6.0.37,linux-3.8.13-amd64)编译它们并与od比较文件。test1.class000000006614307154102016306256407216302006100517307301200000200645570201440675

java - finally 添加 return 隐藏异常

我有以下代码publicstaticvoidnocatch(){try{thrownewException();}finally{}}哪个给出了错误Exceptioninthread"main"java.lang.Error:Unresolvedcompilationproblem:UnhandledexceptiontypeCustomException这是预期的,但是在finallyblock中添加一个return语句会使错误消失publicstaticvoidnocatch(){try{thrownewException();}finally{return;//makesthee