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

  • 相关阅读:
    201920201学期20192407《网络空间安全专业导论》第一周学习总结
    JavaEEJSP详解
    JavaEEJSP指令
    JavaSE类与对象
    JavaSE基础知识
    JavaEEEL表达式
    JavaSE关键字
    JavaSE抽象类、内部类、接口
    JavaSE面向对象
    绪论
  • 原文地址:https://www.cnblogs.com/zzq-include/p/13149588.html
Copyright © 2011-2022 走看看