zoukankan      html  css  js  c++  java
  • java字节码,异常部分分析

    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;  其实在底层字节码实际的赋值操作都是在构造方法内部完成的

  • 相关阅读:
    element-ui 刷新页面不能自动打开对应的菜单
    cookie
    cdn
    为已有文件添加 d.ts 声明
    WiFi 漫游过程
    Wifi 4 way handshake 四次握手
    WiFi association request/response
    WiFi beacon
    WiFi Auth/Deauth帧
    WiFi probe request/response
  • 原文地址:https://www.cnblogs.com/zzq-include/p/13149588.html
Copyright © 2011-2022 走看看