try catch finally

try catch finally 层次结构

三个关键字一般同时出现在某个方法或者代码块中:如果try出现,catch finally 可以同时出现也可以只出现一个,但不能一个都不出现。若有finally代码块则必执行,无论try 或者catch代码块中有无异常抛出。
一般形如:

 try {
	// 代码
 } catch (Throwable throwable) {
     // 代码
 } finally {
     // 代码
 }

执行顺序

代码执行是按照try 、 catch 、finally 顺序执行的,也就是先执行try中的逻辑,然后catch中的逻辑,最后是finally的逻辑,其中catch 中的逻辑不是必须执行,只有当try中抛出的异常,catch中有对应的捕获才会走catch逻辑。

使用注意点

在需要返回值的情况下,返回值总是最后一个return对应的值。
异常抛出到上层也是和return同样的情况,最后面执行抛出的异常才是抛出到上层方法执行的异常。
因此,这里要特别注意,如果在try catch finally 中写了多个return语句或者抛出多个异常。注意异常或者返回可能被覆盖问题。
java 中是值传递(复制一份值传递出去)不是引用传递。这个值可以是真实值,也可以是引用的地址值。
在return的时候总是记住当前返回的值并在执行完后续代码后执行返回。

多返回覆盖的举例:

public class TestTryCatchFinally {
    public static void main(String[] args) {
        try {
            System.out.println("main 处-->> " + testPerson());
        } catch (Exception e) {
            e.printStackTrace();
        }

    }
    public static Person testPerson() {
        Person person = new Person();
        try {
            person.age = 1;
            person.name = "try";
            System.out.println("try 处 -->> " + person);
            return person;
        } finally {
            person = new Person();
            person.name = "finally";
            System.out.println("finally 处 ->> " + person);
            return person;
        }
    }

     static class Person {
        public Person() {
        }
        String name;
        int age;

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public int getAge() {
            return age;
        }

        public void setAge(int age) {
            this.age = age;
        }

        @Override
        public String toString() {
            return "Person{" +
                    "name='" + name + '\'' +
                    ", age=" + age +
                    '}';
        }
    }
}

打印结果:

try 处 -->> Person{name='try', age=1}
finally 处 ->> Person{name='finally', age=0}
main 处-->> Person{name='finally', age=0}
在try 、finally 是两个person对象。结果返回的是finally的对象,而不是try的对象。

多异常覆盖的例子:

import java.lang.reflect.Parameter;

public class TestTryCatchFinally {
    public static void main(String[] args) {
        try {
            System.out.println("main 处-->> " + testPerson());
        } catch (Exception e) {
            e.printStackTrace();
        }

    }
    public static Person testPerson() {
        Person person = new Person();
        try {
            person.age = 1;
            person.name = "try";
            Integer.parseInt(null);
            System.out.println("try 处 -->> " + person);
            return person;
        } finally {
            String b = (String)(new Object());
            person = new Person();
            person.name = "finally";
            System.out.println("finally 处 ->> " + person);
        }
    }

     static class Person {
        public Person() {
        }
        String name;
        int age;

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public int getAge() {
            return age;
        }

        public void setAge(int age) {
            this.age = age;
        }

        @Override
        public String toString() {
            return "Person{" +
                    "name='" + name + '\'' +
                    ", age=" + age +
                    '}';
        }
    }
}

打印结果:

java.lang.ClassCastException: java.lang.Object cannot be cast to java.lang.String
	at TestTryCatchFinally.testPerson(TestTryCatchFinally.java:21)
	at TestTryCatchFinally.main(TestTryCatchFinally.java:6)
	
	由打印可见,抛出的不是try中的NumberFormatException异常,而是finlally中的ClassCastException。

另外一个例子:

public class TestTryCatchFinally {
    public static void main(String[] args) {
        try {
            System.out.println("main 处-->> " + testPerson());
        } catch (Exception e) {
            e.printStackTrace();
        }

    }
    public static Person testPerson() {
        Person person = new Person();
        try {
            person.age = 1;
            person.name = "try";
            System.out.println("try 处 -->> " + person);
            return person;
        } finally {
            person = new Person();
            person.name = "finally";
            System.out.println("finally 处 ->> " + person);
        }
    }

     static class Person {
        public Person() {
        }
        String name;
        int age;

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public int getAge() {
            return age;
        }

        public void setAge(int age) {
            this.age = age;
        }

        @Override
        public String toString() {
            return "Person{" +
                    "name='" + name + '\'' +
                    ", age=" + age +
                    '}';
        }
    }
}

打印结果:

try 处 -->> Person{name='try', age=1}
finally 处 ->> Person{name='finally', age=0}
main 处-->> Person{name='try', age=1}
返回到main函数的结果是在try代码块中创建的name为try的person对象,而不是在finally代码块中更改后的name为finally的person对象,可见return标记了返回了的值,不可更改。

综上:
返回的时候是能执行到的最后一个return后面对应的值(例子中是引用地址值),finally关键字后面的代码块一定会执行。若前面已经执行return,则return标记变量(这里变量指person,实际上标记了变量对应的引用地址值),后续逻辑即使改变了变量指向的地址值,因此并不对return的结果产生任何影响。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
try catch finally是一种异常处理机制,用于在程序中捕获和处理异常。它的基本语法如下: ```java try { // 可能会抛出异常的代码块 } catch (ExceptionType1 e1) { // 处理ExceptionType1类型的异常 } catch (ExceptionType2 e2) { // 处理ExceptionType2类型的异常 } finally { // 无论是否发生异常,都会执行的代码块 } ``` try块中包含可能会抛出异常的代码。如果在try块中发生了异常,那么程序会跳转到与异常类型匹配的catch块中进行处理。catch块可以有多个,每个catch块处理不同类型的异常。如果没有匹配的catch块,异常会被传递给上层调用栈。 无论是否发生异常,finally块中的代码都会被执行。finally块通常用于释放资源或执行清理操作,例如关闭文件或数据库连接。 以下是一个Javatry catch finally的示例: ```java try { int result = divide(10, 0); System.out.println("Result: " + result); } catch (ArithmeticException e) { System.out.println("Divide by zero error: " + e.getMessage()); } finally { System.out.println("Finally block executed"); } public static int divide(int num1, int num2) { return num1 / num2; } ``` 在上面的示例中,try块中调用了divide方法,该方法可能会抛出ArithmeticException异常。由于除数为0,会触发异常。catch块捕获到异常并打印错误信息。最后,无论是否发生异常,finally块中的代码都会被执行,打印出"Finally block executed"。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值