通过字节码分析this关键字以及异常表的重要作用
public class MyTest3 {
public void test(){
try {
InputStream is = new FileInputStream("test.txt");
ServerSocket serverSocket = new ServerSocket(9999);
serverSocket.accept();
}catch (FileNotFoundException e) {
}catch (IOException ex){
}catch (Exception ex){
}finally {
System.out.println("finally");
}
}
}
-
分析this关键字
-
args_size=1:首先test()是无参实例方法[每一个非静态方法都可以叫做实例方法],实际上,每一个实例方法的第一个参数都是隐含着指向this,这也是为什么每一个方法都可以使用this去引用当前类中的任意一个属性或者是任意一个实例方法。
-
对于java类中的每一个实例方法(非static方法),其在编译后所生成的字节码当中,方法参数的数量总是比源代码中方法参数的数量多一个(this),它位于方法的第一个参数位置处;这样,我们就可以在java的实例方法中使用this来去访问当前对象的属性以及其他方法。
这个操作是在编译期间完成的,即由javac编译器在编译的时候将对this的访问转化为一个普通实例方法参数的访问,接下来在运行期间,由JVM在调用实例方法时,自动向实例方法传入该this参数。所以,在实例方法的局部变量表中,至少会有一个指向当前对象的局部变量。
-
locals=4:最多局部变量可能是4个。首先this一个,is一个,serverSocket一个,剩下的一个是异常ex(三个异常只会执行一个),而且如果没有异常,则变成了3个,因为异常是在运行期间才产生的!!
//下面是反编译的结果: public void test(); descriptor: ()V flags: ACC_PUBLIC Code: //stack:操作数栈的最大深度;locals:表示局部变量;args_size:表示方法参数的个数, stack=3, locals=4, args_size=1
-