深入JVM字节码探索switch枚举

本文探讨了Java中枚举在switch语句中的实现原理,通过字节码分析展示了枚举如何转换为整数表达式,并在静态内部类中使用$SwitchMap$数组进行跳转。当枚举类型改变时,由于类依赖关系,可能导致冗余代码的生成,但这保障了程序在版本不匹配时的健壮性。
摘要由CSDN通过智能技术生成

深入JVM字节码探索switch枚举

本文主要讨论对枚举switch的实现原理。

以下代码作为示例:

enum Foobar {
   
    FOO,
    BAR;
}
class Test {
   
    static int test(Foobar var0) {
   
        switch (var0) {
   
            case FOO:
                return 1;
            case BAR:
                return 2;
            default:
                return 0;
        }
    }
}

编译后的字节码:

Compiled from "Test.java"
class Test {
   
  Test();
    Code:
       0: aload_0
       1: invokespecial #1                  // Method java/lang/Object."<init>":()V
       4: return

  static int test(Foobar);
    Code:
       0: getstatic     #2                  // Field Test$1.$SwitchMap$Foobar:[I
       3: aload_0
       4: invokevirtual #3                  // Method Foobar.ordinal:()I
       7: iaload
       8: lookupswitch  {
    // 2
                     1: 36
                     2: 38
               default: 40
          }
      36: iconst_1
      37: ireturn
      38: iconst_2
      39: ireturn
      40: iconst_0
      41: ireturn
}
Compiled from "Test.java"
class Test$1 {
   
  static final int[] $SwitchMap$Foobar;

  static {
   };
    Code:
       0: invokestatic  #1                  // Method Foobar.values:()[LFoobar;
       3: arraylength
       4: newarray       int
       6: putstatic     #2                  // Field $SwitchMap$Foobar:[I
       9: getstatic     #2                  // Field $SwitchMap$Foobar:[I
      12: getstatic     #3                  // Field Foobar.FOO:LFoobar;
      15: invokevirtual #4                  // Method Foobar.ordinal:()I
      18: iconst_1
      19: iastore
      20
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值