java字节码,异常部分分析

2021-05-11 23:28

阅读:401

标签:except   new   ack   隐式   显示   转换   exce   范围   操作   

public class Test {
    public void set(int i) {
        try {
            InputStream inputStream = new FileInputStream("abnc.txt");
            ServerSocket socketAddress = new ServerSocket(9999);
            socketAddress.accept();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
        }

    }
}

1 set方法在字节码层面默认会有两个参数,第一个参数是this这样能够保证我们调用实例对象的方法时候正常调用(可以理解成和一些解释类型的语言类似,只不过java在底层生成字节码隐式加上了this,对我们透明的)。

2 在set方法字节码显示局部变量有4个,this是一个,inputStream ,socketAddress ,还有另一个就是一旦出现异常时的变量e。

3 try cache在编译成字节码后,会将每条语句转换成jvm,16进制指令执行,针对指令解析后我们可以标记为注记符。针对于异常来说,java在字节码层面使用goto语句加上start_pc和end_pc以及handle_pc指令进行记录,从某一行开始到谋一行结束使用start_pc和end_pc进行标记,如果当前范围内出现异常则使用goto语句跳转到指定的catch位置。那么在cache位置后面紧跟着finally执行的语句,字节码层面每一个catch后面都会跟上一个finally,并不是java源代码层面看到的只有一个finally

ps:而且在这里提一句,在java源文件中如果有直接常量,类似于public  int a=16;  其实在底层字节码实际的赋值操作都是在构造方法内部完成的

java字节码,异常部分分析

标签:except   new   ack   隐式   显示   转换   exce   范围   操作   

原文地址:https://www.cnblogs.com/zzq-include/p/13149588.html


评论


亲,登录后才可以留言!