try catch finally 一个小测试

之前没有注意到,现在记录下

try{

}catch{

}finally{

}

这种结构,大家都知道finally一定会执行,但如果涉及到return result  这种返回值的方法时,是有点差别的

正常的如下:

 private static String testString(){

        String  s = "0000000000";

        try{

            System.out.println("111111111111111111111111");
            s = "1111111111";
            return s;
        }catch (Exception e){
            System.out.println("222222222222222");
        }finally {
            System.out.println("333333333333333333333");
            s = "33333333333";
        }

        System.out.println("44444444444444444444444");
        s = "4444444444";
        return s;
    }

这种String 返回值 的 try  catch  finally 块,大家很容易分析出来

1. finally 里面的肯定会执行

2. return 后面的代码(finally除外)不再执行

测试:

   System.out.println("testString:"+testString());

结果:

111111111111111111111111
333333333333333333333
testString:1111111111

复合结构:

 private static Map testMap(){

      Map m = new HashMap();

        try{

            System.out.println("111111111111111111111111");
            m.put("aaa", "1111111111");
            return m;
        }catch (Exception e){
            System.out.println("222222222222222");
        }finally {
            System.out.println("333333333333333333333");
            m.put("aaa", "33333");
        }

        System.out.println("44444444444444444444444");
        m.put("aaa", "4444");
        return m;
    }

直接测试:

  System.out.println("testMap:"+testMap());

结果:

111111111111111111111111
333333333333333333333
testMap:{aaa=33333}

唯一变化的就是返回值,不像前面String那样,返回的是return 语句执行到时变量的值

而是finally块执行完后的值,个人感觉是因为变量是引用的原因

同理验证了List

 private static List testList(){
        List list = new ArrayList();
        list.add("0000000000");

        try{

            System.out.println("111111111111111111111111");
            list.add("1111111111");
            return list;
        }catch (Exception e){
            System.out.println("222222222222222");
        }finally {
            System.out.println("333333333333333333333");
            list.add("333333333333");
        }

        System.out.println("44444444444444444444444");
        list.add("44444444444444");
        return list;
    }

结果:

111111111111111111111111
333333333333333333333
testList:[0000000000, 1111111111, 333333333333]

同上面分析一样

于是联想到是不是将String  s = “111111111”,变为String  s = new String(“111111111”)。

 private static String testStringObj(){

        String  s = new String("0000000000");

        try{

            System.out.println("111111111111111111111111");
            s = new String("1111111111");
            return s;
        }catch (Exception e){
            System.out.println("222222222222222");
        }finally {
            System.out.println("333333333333333333333");
            s = new String("33333333333");
        }

        System.out.println("44444444444444444444444");
        s = new String("4444444444");
        return s;
    }

结果:

111111111111111111111111
333333333333333333333
testStringObj:1111111111

竟然没什么变化,不符合预期。

目前个人感觉可能同String 这个比较特殊,或者因为String是 final的,后续有时间研究下(刚才又被催干活了),或者研究过的同学给说下,多谢多谢!

在Java中,`try-catch-finally`语句结构是用来处理程序中的异常情况的关键组成部分。这个结构主要用于以下目的: 1. **Try block**(尝试块):这部分包含可能会抛出异常的代码。如果这段代码执行期间发生了异常,控制权会被转移到相应的catch块。 2. **Catch block**(捕获块):每个`catch`子句定义了一个异常类型,用于捕获并处理特定类型的异常。当try块中指定的异常发生时,该catch块中的代码会被执行。你可以有多个catch块,以便处理不同类型的异常或提供默认处理。 3. **Finally block**(最终块):无论是否出现异常,finally块中的代码都会被执行。这通常用来释放资源(如数据库连接、文件流等),因为它们即使在异常情况下也需要被关闭。即使程序因未捕获的异常而终止,finally块也会被执行。 举个例子: ```java try { // 可能引发异常的操作,例如文件读写、网络请求等 FileReader file = new FileReader("file.txt"); // ... } catch (FileNotFoundException e) { // 捕获 File Not Found 异常并处理 System.out.println("File not found: " + e.getMessage()); } catch (IOException e) { // 捕获所有 IOException 类型的异常并处理 System.out.println("An IO error occurred: " + e.getMessage()); } finally { // 不管是否出现异常,都确保关闭文件 try { if (file != null) { file.close(); } } catch (IOException e) { System.out.println("Error closing file: " + e.getMessage()); } } ``` 在这个例子中,finally块保证了`FileReader`对象总是会被正确关闭,不论try-catch块内是否有异常抛出。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值