《深入理解JVM》-java字节码-张龙

本文详细解析了十六进制与二进制的关系,揭示了一位十六进制如何表示二进制的4位,以及两位十六进制如何组成一个字节。同时,深入探讨了<init>和<clinit>方法在Java中的作用,解释了synchronized关键字在字节码层面的实现机制,以及JVM对实例方法和静态方法的处理方式。此外,还介绍了Java字节码异常处理机制和JVM参数设置规则。
摘要由CSDN通过智能技术生成

十六进制一位表示二进制的4位,也就是2的4次方=16,一位十六进制表示二进制0000~1111之间的任意值,所以两位16进制数表示一个字节(一个字节表示8位)

 

 

 

<init>方法是自动生成的无参构造方法,一个构造方法对应一个<init>方法,两个构造方法则对应两个<init>方法,通过分析字节码可知我们对成员变量的赋值实际上是在<init>方法中进行赋值;

如果有静态属性或静态代码块,则会额外生成<clinit>方法,然后静态属性的初始化在<clinit>方法中执行,只会生成一个<clinit>方法,并且静态代码块和静态属性会统一在<clinit>中执行

synchronize锁转成字节码是monitorenter和monitorexit成对出现

实例方法的synchronize是对当前对象this加锁,静态方法的synchronize是对当前对象的Class对象上锁

对于java类中的每一个实例方法(非static)方法,其在编译后生成的字节码当中,方法参数的数量总是会比源代码中方法参数的数量多一个(this),它位于方法的第一个参数位置处;这样,我们就可以在java的实例方法中使用this来去访问当前对象的属性以及其他方法。

这个操作是在编译期间完成的,即由javac编译器在编译的时候将对this的访问转化为对一个普通实例方法参数的访问;接下来再运行期间,由JVM在调用实例方法时,自动向实例方法传入该this参数。所以,在实例方法的局部变量表中,至少会有一个指向当前对象的局部变量。

java字节码对于异常的处理方式: 1.统一采用异常表的方式来对异常进行处理。 2.在jdk 1.4.2之前的版本中,并不是使用异常表的方式来对异常进行处理的,而是采用特定的指令方式。 2.当异常处理存在finally语句块时,现代化的JVM采取的处理方式是将finally语句块的字节码拼接到每一个catch块后面,换句话说,程序中存在多少个catch块,就会在每一个catch块后面重复多少个finally语句块的字节码。

JVM设置参数规则:

-XX:+<option>   表示开启option选项

-XX:-<option>    表示关闭option选项

-XX:<option>=<value>  表示将option选项的值设置为true

JVM常见参数设置:

-XX:+TraceClassLoading,用于追踪类的加载信息并打印出来

-XX:+TraceClassUnloading,用户追踪类的卸载信息并打印出来

 JVM中常用命令:

javap xxxx.class,反编译class文件

javap -c xxxx.class,反编译class文件

javap -verbose xxxx.class,反编译class文件

JVM中助记符:

idc表示将int、float或是String类型的常量值从常量池中推送至栈顶

bipush表示将单字节(-128~127)的常量值推送至栈顶

sipush表示将一个短整型常量值(-32768~32767)推送至栈顶

iconst_1表示将int类型1对推送至栈顶(iconst_1~iconst_5)

anewarray:表示创建一个引用类型的(如类、接口、数组)数组,并将其引用值压入栈顶

newarray:表示创建一个指定的原始类型(如int、float、char等)的数组,并将其引用值压入栈顶

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值