jvm——字节码中的方法的执行分析
程序员文章站
2024-03-16 23:18:28
...
1、代码
package com.bytecode;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
/**
* @author dc
* @date 2020/6/24 - 16:22
*/
public class MyTest3 {
/**
* 对于java类中的每一个实例方法(非static方法),其在编译后所生成的字节码当中,方法参数的数量多
* 一个(this),它位于方法的第一个参数位置处;这样我们就可以在java的实例方法中使用this来访问当
* 前对象的属性及其它方法。
*
*
* 这个操作实在编译期间完成的,即由javac编译器在编译的时候将对this的访问转化为对一个普通实例方法
* 参数的访问,接下来在运行期间,由jvm调用实例方法时,自动向实例方法传入该this参数。所以,在实例
* 方法的局部变量表中,至少会有一个指向当前对象的局部变量。
*/
/**
* java字节码对于异常的处理方式:
*
* 1、统一采用异常表的方式来对异常进行处理。
* 2、在jdk1.4.2之前的版本中,并不是使用异常表的方式来对异常进行处理的,而是采用特定的指令方式
* 3、当异常处理存在finally语句块时,现代化的jvm采取的处理方式是将finally语句块的字节码拼接到每一个
* catch语句块后面,换句话说,程序中存在多少个catch语句块,就会在每一个catch语句块后面重复多少个
* finally语句块字节码。
*/
public void test() throws FileNotFoundException, IOException{
try {
InputStream is = new FileInputStream("test.txt");
ServerSocket serverSocket = new ServerSocket(9999);
serverSocket.accept();
}catch (FileNotFoundException ex) {
System.out.println("抛出了FileNotFoundException异常");
}catch (IOException ex) {
System.out.println("抛出了IOExcption异常");
}catch (Exception ex) {
System.out.println("抛出了Exception异常");
}finally {
System.out.println("执行了finally代码块");
}
}
/**
* 在方法中对于异常的处理方式有两种:throws抛出、try——catch捕获异常
* 这两种方式反映在字节码中是不同的,若采用捕获的方式,那么该方式体现在方法体中;
* 若采用抛出的方式,那么这种方式抛出的异常会与方法体并列存在。
*/
}