草庐IT

Try-catch-finally

全部标签

Java 7 -> Java 8 : AES Causes exception: "BadPaddingException: Given final block not properly padded" in conjunction with BufferedReader & ZipStreams

我们使用以下语句实例化密码:Ciphercipher=Cipher.getInstance("AES");SecretKeySpeckey=newSecretKeySpec(cipherKey,"AES");这在Java7(1.7_45)中有效,但在Java8(1.8_25)中不再有效。我们将cipher传递给CipherInputStream并使用流来读取/写入数据。实际异常发生在close期间。编辑:快速查看JDK代码会发现BadPaddingException被重新抛出,在7中它被忽略了:JDK7:CipherInputStream.close:try{this.cipher.d

java - 关键字 final 对 JVM 有什么影响吗?

这个问题在这里已经有了答案:DoesuseoffinalkeywordinJavaimprovetheperformance?(14个答案)关闭7年前。现在,我最近遇到了一条建议,建议您应尽可能广泛地使用关键字final。这很好,可以防止程序员开枪打自己的腿——也就是说,重新分配不应重新分配的变量。但是,它还有其他目的吗?也就是说,JVM能否使用有关最终变量的信息以某种方式优化字节码,使其运行得更快(构建更好的流水线或在多线程环境中使用它)?或者只是一种语法糖,可以最大限度地减少代码开发过程中出错的可能性?

java try catch 异常后还会继续执行吗

1、有try-catch语句块,并且throw在catch语句块里,那么try语句块中引发异常(报错)的那一行代码的后续代码都不执行并且catch语句块后的代码也都不执行(遇到finally除外)。(见情形一和情形二)2、有try-catch语句块,并且throw在try语句块里,那么try语句块中引发异常(报错)的那一行代码的后续代码都不执行,但是catch语句块后的代码会继续执行。(见情形三)3、有try-catch语句块,但是没有throw语句,那么try语句块中引发异常(报错)的那一行代码的后续代码都不执行,但是catch语句块后的代码会继续执行。(见情形四)4、有try-catch语

java - 为什么 Java 的 BigDecimal 类没有声明为 final?

在检查Java的源代码时BigDecimal类,令我惊讶的是它未声明为最终类:ClassBigDecimalpublicclassBigDecimalextendsNumberimplementsComparableImmutable,arbitrary-precisionsigneddecimalnumbers.(来自OracleDocs)这是否有特定原因,或者开发人员只是忘记添加该关键字?不将不可变类声明为final是一种好习惯吗?BigInteger也是如此,但不适用于String这被宣布为最终的。 最佳答案 引自https:

java - 在一个 catch block 中使用多个异常有什么好处?

我们都听说在Java7中我们可以这样写:try{//somethingwithfilesandIO}catch(FileNotFoundException|IOExceptionex){ex.printStackTrace();System.out.println("It'scan'tcopyfile");}代替try{//somethingwithfilesandIO}catch(FileNotFoundExceptionwx){ex.printStackTrace();}catch(IOExceptionex){ex.printStackTrace();}但是,除了更短的代码之外,

java - 为什么 static final 在每次迭代中都比 new 慢

为什么代码片段A比代码片段B慢14倍?(在Windows764位上使用jdk1.8.0_60测试)代码片段A:importjava.awt.geom.RoundRectangle2D;publicclassTest{privatestaticfinalRoundRectangle2D.DoubleRECTANGLE=newRoundRectangle2D.Double(1,2,3,4,5,6);publicstaticvoidmain(String[]args){intresult=RECTANGLE.hashCode();longstart=System.nanoTime();for

java - 为什么我不能将 final long 分配给 int?

据我了解,变量评估是在运行时完成的。但是,在Java中,类型评估是在编译时完成的。此外,如我所见,将变量设置为常量(我使用的是局部变量,但它对上述概念没有任何改变),将在编译时使其值已知。我为您提供了两个示例来验证这个概念。第一个有效,第二个无效。有人可以向我解释为什么使变量常量允许我将一个short变量分配给一个int变量,而我不能将一个int变量分配给一个long变量吗?//Workingexamplefinalintx=10;shorty=x;//Non-workingexamplefinallonga=10L;intb=a; 最佳答案

java - 为什么 try catch 中的 return 语句与 'throws' 一起工作

不起作用(编译错误:缺少返回语句)publicSqlMapClientTemplategetSqlTempl()throwsUivException,SQLException{try{SqlMapClientscl=(SqlMapClient)ApplicationInitializer.getApplicationContext().getBean("MySqlMapClient");DataSourcedsc=(DataSource)ServiceLocator.getInstance().getDataSource(PIH_EIV_ORCL);returnnewSqlMapCli

java - try/catch 是不是很耗资源的操作?

我听说与其抛出异常并在try/catchblock中捕获它们,不如在方法中返回null更合理,因为try/catch是消耗资源的操作。这是真的吗? 最佳答案 Try/catch仅在抛出异常时占用大量资源,否则几乎不需要。当它们使程序更干净时使用它们。返回null也可以。这取决于 关于java-try/catch是不是很耗资源的操作?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/

java - 为什么 Java 8 中的 lambda 表达式要求其内部使用的变量使用 "final"修饰符,但在使用方法引用时却不需要?

这个问题在这里已经有了答案:Whycanmethodreferenceusenon-finalvariables?(4个答案)关闭去年。考虑以下类(class):classFoo{voidhandle(Tt){System.out.println("handling"+t);}publicstaticvoidmain(String[]args){Listlist=newArrayList();list.add(1);list.add(2);Foof=newFoo();list.forEach(f::handle);//compilesfine//list.forEach(obj->f.