查看Java字节码内容的几种方式

简介: 查看Java字节码内容的几种方式

1、javap

通过javacjavap查看:先通过javac.java文件编译成.class字节码文件,然后通过javap -verbose分析字节码。

(base) tinytongtongdeMacBook-Pro% javac JVMRunTimeStorageTest.java
(base) tinytongtongdeMacBook-Pro% javap -verbose JVMRunTimeStorageTest

这样你就能看到你的字节码信息了。

示例如下:

Classfile /Users/wangjianzhou/Documents/workspace/java/JavaStudy/src/com/tinytongtong/javastudy/jvm/JVMRunTimeStorageTest.class
  Last modified Mar 16, 2022; size 657 bytes
  MD5 checksum a13778df0b853b554f2a5da237c53672
  Compiled from "JVMRunTimeStorageTest.java"
public class com.tinytongtong.javastudy.jvm.JVMRunTimeStorageTest
  minor version: 0
  major version: 52
  flags: ACC_PUBLIC, ACC_SUPER
Constant pool:
   #1 = Methodref          #5.#21         // java/lang/Object."<init>":()V
   #2 = Double             2.0d
   #4 = Class              #22            // com/tinytongtong/javastudy/jvm/JVMRunTimeStorageTest
   #5 = Class              #23            // java/lang/Object
   #6 = Utf8               <init>
   #7 = Utf8               ()V
   #8 = Utf8               Code
   #9 = Utf8               LineNumberTable
  #10 = Utf8               main
  #11 = Utf8               ([Ljava/lang/String;)V
  #12 = Utf8               add
  #13 = Utf8               (I)I
  #14 = Utf8               add1
  #15 = Utf8               add2
  #16 = Utf8               ()I
  #17 = Utf8               foreach
  #18 = Utf8               StackMapTable
  #19 = Utf8               SourceFile
  #20 = Utf8               JVMRunTimeStorageTest.java
  #21 = NameAndType        #6:#7          // "<init>":()V
  #22 = Utf8               com/tinytongtong/javastudy/jvm/JVMRunTimeStorageTest
  #23 = Utf8               java/lang/Object
{
  public com.tinytongtong.javastudy.jvm.JVMRunTimeStorageTest();
    descriptor: ()V
    flags: ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
         0: aload_0
         1: invokespecial #1                  // Method java/lang/Object."<init>":()V
         4: return
      LineNumberTable:
        line 8: 0

  public static void main(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: ACC_PUBLIC, ACC_STATIC
    Code:
      stack=0, locals=1, args_size=1
         0: return
      LineNumberTable:
        line 12: 0

  public static int add(int);
    descriptor: (I)I
    flags: ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=1
         0: iconst_1
         1: istore_1
         2: iconst_2
         3: istore_2
         4: iload_1
         5: iload_2
         6: iadd
         7: iload_0
         8: iadd
         9: ireturn
      LineNumberTable:
        line 28: 0
        line 29: 2
        line 30: 4

  public static int add1(int);
    descriptor: (I)I
    flags: ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=5, args_size=1
         0: lconst_1
         1: lstore_1
         2: ldc2_w        #2                  // double 2.0d
         5: dstore_3
         6: lload_1
         7: l2d
         8: dload_3
         9: dadd
        10: iload_0
        11: i2d
        12: dadd
        13: d2i
        14: ireturn
      LineNumberTable:
        line 42: 0
        line 43: 2
        line 44: 6

  public static int add2();
    descriptor: ()I
    flags: ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=0
         0: iconst_1
         1: istore_0
         2: iconst_2
         3: istore_1
         4: iload_0
         5: iload_1
         6: iadd
         7: istore_2
         8: iload_2
         9: bipush        10
        11: iadd
        12: ireturn
      LineNumberTable:
        line 55: 0
        line 56: 2
        line 57: 4
        line 58: 8

  public static int foreach(int);
    descriptor: (I)I
    flags: ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=1
         0: iconst_0
         1: istore_1
         2: iconst_0
         3: istore_2
         4: iload_2
         5: iload_0
         6: if_icmpge     19
         9: iload_1
        10: iload_2
        11: iadd
        12: istore_1
        13: iinc          2, 1
        16: goto          4
        19: iload_1
        20: ireturn
      LineNumberTable:
        line 70: 0
        line 71: 2
        line 72: 9
        line 71: 13
        line 74: 19
      StackMapTable: number_of_entries = 2
        frame_type = 253 /* append */
          offset_delta = 4
          locals = [ int, int ]
        frame_type = 250 /* chop */
          offset_delta = 14
}
SourceFile: "JVMRunTimeStorageTest.java"

demo-JVMRunTimeStorageTest

2、ASM Bytecode Outline 插件

给IDE安装ASM Bytecode Outline插件。

安装好之后,重启IDE。

接着选择对应的java文件,右键 --> Show Bytecode outline,可以看到ASM的输出,如下图所示
在这里插入图片描述
在这里插入图片描述

3、jclasslib Bytecode Viewer

jclasslib Bytecode Viewer

我们可以通过这个插件,以可视化的方式查看字节码中的信息,比如方法Code表中的局部变量表信息。如下图所示:

打开对应的java文件,View --> Show Bytecode With Jclasslib
在这里插入图片描述
在这里插入图片描述

我们可以看到局部变量表的长度。

相关文章
|
5月前
|
安全 Java API
JDK 11中的动态类文件常量:探索Java字节码的灵活性与动态性
在JDK 11中,Java语言引入了一个新的特性,允许在运行时动态地修改类文件常量。这一特性为Java开发者提供了更大的灵活性,使他们能够根据需要在运行时更改类文件中的常量值。本文将深入探讨动态类文件常量的工作原理、优点、限制以及在实际项目中的应用。
123 11
|
29天前
|
Arthas Java 测试技术
Java字节码文件、组成,jclasslib插件、阿里arthas工具,Java注解
Java字节码文件、组成、详解、分析;常用工具,jclasslib插件、阿里arthas工具;如何定位线上问题;Java注解
Java字节码文件、组成,jclasslib插件、阿里arthas工具,Java注解
|
27天前
|
Java API 开发者
【Java字节码操控新篇章】JDK 22类文件API预览:解锁Java底层的无限可能!
【9月更文挑战第6天】JDK 22的类文件API为Java开发者们打开了一扇通往Java底层世界的大门。通过这个API,我们可以更加深入地理解Java程序的工作原理,实现更加灵活和强大的功能。虽然目前它还处于预览版阶段,但我们已经可以预见其在未来Java开发中的重要地位。让我们共同期待Java字节码操控新篇章的到来!
|
25天前
|
Java API 开发者
【Java字节码的掌控者】JDK 22类文件API:解锁Java深层次的奥秘,赋能开发者无限可能!
【9月更文挑战第8天】JDK 22类文件API的引入,为Java开发者们打开了一扇通往Java字节码操控新世界的大门。通过这个API,我们可以更加深入地理解Java程序的底层行为,实现更加高效、可靠和创新的Java应用。虽然目前它还处于预览版阶段,但我们已经可以预见其在未来Java开发中的重要地位。让我们共同期待Java字节码操控新篇章的到来,并积极探索类文件API带来的无限可能!
|
5月前
|
设计模式 Java 程序员
【设计模式】JAVA Design Patterns——Bytecode(字节码模式)
【设计模式】JAVA Design Patterns——Bytecode(字节码模式)
|
2月前
|
监控 Java API
分布式链路监控系统问题之对Java应用实现字节码增强的方式的问题如何解决
分布式链路监控系统问题之对Java应用实现字节码增强的方式的问题如何解决
|
3月前
|
存储 Java
JAVA程序运行问题之编译生成的字节码在不同的平台上是否相同如何解决
JAVA程序运行问题之编译生成的字节码在不同的平台上是否相同如何解决
|
3月前
|
存储 运维 Java
Java中的字节码与JVM指令集详解
Java中的字节码与JVM指令集详解
|
11月前
|
安全 算法 Java
从零开发基于ASM字节码的Java代码混淆插件XHood
因在公司负责基础框架的开发设计,所以针对框架源代码的保护工作比较重视,之前也加入了一系列保护措施,例如自定义classloader加密保护,授权license保护等,但都是防君子不防小人,安全等级还比较低,经过调研各类加密混淆措施后,决定自研混淆插件,自主可控,能够贴合实际情况进行定制化,达到框架升级后使用零感知,零影响
115 1
从零开发基于ASM字节码的Java代码混淆插件XHood
|
4月前
|
Java 对象存储
字节码学习之常见java语句的底层原理
字节码学习之常见java语句的底层原理
35 0
下一篇
无影云桌面