草庐IT

Try-catch-finally

全部标签

java - 在 try block 中返回 vs 在 block 后返回

我在一个小型静态方法中有一个try语句,是否有关于我应该从哪里返回的最佳实践?try{mightThrow();returntrue;}catch(Exceptione){returnfalse;}或之后,try{mightThrow();}catch(Exceptione){returnfalse;}returntrue;在功能上,这些应该执行相同,实际上有字节码差异吗?性能方面,它们完全相同吗?或者只是一个比另一个更受欢迎?哪个以及为什么? 最佳答案 我还没有听说过这方面的实际最佳实践,但您经常会看到,当方法使用过早返回时,返回

java - 变量在 catch block 后立即被垃圾收集

我可以从垃圾收集器中看到这种奇怪的行为publicclassA{publicstaticvoidmain(String[]args){Stringfoo;try{foo="bar";intyoo=5;//1}catch(Exceptione){}intfoobar=3;//2}}如果我去调试并在//1foo不是null并且它的值为“bar”但在断点处放置断点//2foo是null,这在调试时可能很难理解。我的问题是是否有任何规范说明这是垃圾收集器的合法行为有了这个小变化,它就不会收集垃圾:publicclassA{publicstaticvoidmain(String[]args){S

java - Java 6 中 if/or 与 try/catch 的复合成本

我们目前有以下复合if语句...if((billingRemoteService==null)||billingRemoteService.getServiceHeader()==null||!"00".equals(billingRemoteService.getServiceHeader().getStatusCode())||(billingRemoteService.getServiceBody()==null)||(billingRemoteService.getServiceBody().getServiceResponse()==null)||(billingRemote

java - 优雅地退出应用程序?

我有一个具有定义良好的Try/Catch/Finally链的应用程序,它在正常情况下退出并执行finallyblock,但是当有人过早地点击GUI中的红色X时,程序完全存在(代码=0)并且主线程的finallyblock没有被调用。事实上,我确实希望程序在单击红色X时退出,但我不希望跳过finally{}block!我在GUI中手动放入了finallyblock最重要的部分,但我真的不想这样做,因为我希望GUI与实际程序分离:classGUI{//......mainFrame.addWindowListener(newWindowAdapter(){publicvoidwindowC

Java:Try/Catch 语句:捕获到异常时,是否重复 try 语句?

这个问题在这里已经有了答案:Howdoyouimplementare-try-catch?(29个答案)关闭4年前。有什么办法吗?//Examplefunctiontakinginfirstandlastnameandreturningthelastname.publicvoidlastNameGenerator()throwsException{try{StringfullName=JOptionPane.showInputDialog("Enteryourfullname");StringlastName=fullName.split("\\s+")[1];catch(IOExce

java - 在 java 中使用 final 关键字从 int 到 byte 的类型转换问题

publicstaticvoidmain(String[]args){finalinta=15;byteb=a;System.out.println(a);System.out.println(b);}在上面的代码中,当我从int转换为byte时,它​​没有给出编译时错误,但是当我从long转换为int时,它给出了编译时错误,为什么?publicstaticvoidmain(String[]args){finallonga=15;intb=a;System.out.println(a);System.out.println(b);} 最佳答案

Java try-finally 竞争条件?

很多Java资源使用示例如下所示:Resourcer=openResource();try{//useresource}finally{r.close();}r的声明必须在try子句之外才能在finally子句中可见,但这也使得看起来可能存在竞争条件:如果在openResource()调用和进入try子句之间出现线程中断怎么办?这是否意味着资源不会在那种情况下实际上被关闭?或者Java是否保证try-finally会“完全”覆盖r,尽管语法看起来不会?或者我必须写:Resourcer=null;try{r=openResource();//useresource}finally{if(

java - 为什么在 Java 中初始化为 String.toString() 的 'final String' 不被视为常量

这个问题在这里已经有了答案:Javaswitchstatement:Constantexpressionrequired,butitISconstant(14个答案)CompileTimeConstantUsageinSwitchCaseJava(6个答案)关闭6年前。我用Java编写了以下代码,运行良好:publicclasstest{publicstaticvoidmain(String[]args){finalStrings1="s1";finalStrings2="s2";Strings="s1";switch(s){cases1:System.out.println("s1"

java - 在 try 或 catch block 上调用 return 语句或 System.exit

我在面试中被问到以下问题:WhatwillhappenifonecallsareturnstatementorSystem.exitontryorcatchblock?Willfinallyblockexecute?finallyblock是否总是被执行?编辑:在java中尝试以上操作后:finally如果我将return语句放在tryblock或catchblock中,block就会执行,但是如果我调用System.exit形式的try或catch,finallyblock不会运行。虽然我不明白背后的原因。 最佳答案 Whatwi

java - 为什么在覆盖 finalize() 方法时首选调用 super.finalize()?

我收到SonarQube错误:“强烈建议在此方法实现结束时调用super.finalize(),以防父实现也必须释放一些系统资源。”但我发现Object类没有实现finalize方法。protectedvoidfinalize()throwsThrowable{}那么为什么需要调用super.finalize()呢? 最佳答案 这不是必须的,它是应该遵循的finalizer写成语。如果在未来的任何时候,您重构了您的代码并且您的类扩展了一些可能具有finalize方法的其他类,这种做法将防止出现奇怪的错误。成语是try{//Dowha