草庐IT

Try-finally

全部标签

java - 通过ASM在字节码中添加try/catch block

我是ASM的新手,我需要一些与字节码转换相关的帮助。问题:我想通过ASM为字节码中的整个方法添加try/catchblock,并希望在不使用java-noverify选项的情况下运行该方法。我可以为整个方法添加try/catchblock,但是当我尝试执行该方法时出现“java.lang.VerifyError”。如果我使用java-noverify选项,那么它将运行。请帮助我。下面是详细信息。publicclassExample{publicstaticvoidhello(){System.out.println("Helloworld");}}我想将上面的代码转换为如下引入try/

java - 如何避免 finally block 中的 throw 子句

我使用SonarQube来提高代码质量。我遇到了一个与异常处理相关的问题,它说从finallyblock中删除throw子句。}catch(Exceptione){thrownewMyException("requestfailed:",e);}finally{try{httpClient.close();}catch(IOExceptione){thrownewMyException("failedtocloseserverconn:",e);}}根据我的理解,上面的代码看起来不错。如果我在finally中删除throw子句并抑制异常,则此方法的调用者将无法知道服务器的状态。我不确定

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

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

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 语句:捕获到异常时,是否重复 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