博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java命令之javap初探
阅读量:6701 次
发布时间:2019-06-25

本文共 4142 字,大约阅读时间需要 13 分钟。

javap是jdk自带的一个工具在jdk安装目录的/bin下面可以找到,可以对代码反编译,也可以查看java编译器生成的字节码,对代码的执行过程进行分析,了解jvm内部的工作。

下面列举javap命令的常用options及其功能描述,更多功能的使用请自行Google,楼主不做赘述。

用法摘要

-help 帮助-l 输出行和变量的表-public 只输出public方法和域-protected 只输出public和protected类和成员-package 只输出包,public和protected类和成员,这是默认的-p -private 输出所有类和成员-s 输出内部类型签名-c 输出分解后的代码,例如,类中每一个方法内,包含java字节码的指令,-verbose 输出栈大小,方法参数的个数-constants 输出静态final常量复制代码

实例分析

javap命令分解一个class文件,它根据options来决定到底输出什么。如果没有使用options,那么javap将会输出该class文件中的包,类里的protected和public域以及类里的所有方法。javap将会把它们输出在标准输出上。来看这个例子,先编译(javac)下面这个类。

package com.thundersoft.metadata.test.kafka;import org.apache.kafka.clients.consumer.ConsumerRecord;import org.apache.kafka.clients.consumer.ConsumerRecords;import org.apache.kafka.clients.consumer.KafkaConsumer;import org.apache.kafka.clients.producer.KafkaProducer;import org.apache.kafka.clients.producer.Producer;import org.apache.kafka.clients.producer.ProducerRecord;import org.junit.Test;import java.util.Arrays;import java.util.Properties;public class KafkaTest {    @Test    public void testProducer() {        Properties props = new Properties();        props.put("bootstrap.servers", "192.168.204.30:9092");        props.put("acks", "all");        props.put("retries", 0);        props.put("batch.size", 16384);        props.put("linger.ms", 1);        props.put("buffer.memory", 33554432);        props.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");        props.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");        Producer
producer = new KafkaProducer<>(props); for(int i = 0; i < 100; i++) { producer.send(new ProducerRecord
("my-topic", Integer.toString(i), Integer.toString(i))); } producer.close(); } @Test public void testKafkaConsumer() { Properties props = new Properties(); props.put("bootstrap.servers", "192.168.204.30:9092"); props.put("group.id", "test"); props.put("enable.auto.commit", "true"); props.put("auto.commit.interval.ms", "1000"); props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer"); props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer"); KafkaConsumer
consumer = new KafkaConsumer<>(props); consumer.subscribe(Arrays.asList("my-topic")); while (true) { ConsumerRecords
records = consumer.poll(100); for (ConsumerRecord
record : records) System.out.printf("offset = %s, key = %s, value = %s%n", record.topic(), record.key(), record.value()); } } public static void main(String[] args) { int a = 2; int b = 3; int sum = a*b; System.out.println(sum); }}复制代码

在命令行上键入javap KafkaTest后,输出结果如下

public class com.thundersoft.metadata.test.kafka.KafkaTest {  public com.thundersoft.metadata.test.kafka.KafkaTest();  public void testProducer();  public void testKafkaConsumer();  public static void main(java.lang.String[]);}复制代码

结合代码分析编译器执行过程

这里只关注main方法内部的代码逻辑,main方法代码如下

public static void main(String[] args) {        int a = 2;        int b = 3;        int sum = a*b;        System.out.println(sum);    }复制代码

在命令行上键入javap -c KafkaTest后,输出结果如下

public static void main(java.lang.String[]);    Code:       0: iconst_2       1: istore_1       2: iconst_3       3: istore_2       4: iload_1       5: iload_2       6: imul       7: istore_3       8: getstatic     #47                 // Field java/lang/System.out:Ljava/io/PrintStream;      11: iload_3      12: invokevirtual #54                 // Method java/io/PrintStream.println:(I)V      15: return复制代码

如上面代码所,iconst_2 与iconst_3分别代表常量2,3 。istore_1 ,istore_2 分别代表定义两个普通变量,iload_1 , iload_2 分别表示加载istore_1,istore_2 两个变量到数据栈中,imul表示两个变量做乘法运算,结果赋值给变量istore_3,最后将结果输出,程序返回。

在分析这段简单代码的过程中,楼主发现了一个jvm编译命令的网站,分享出来。

总结

楼主在上面做了一个简单的代码分析的过程,希望可以帮助到有缘人。javap可以用于反编译和查看编译器编译后的字节码。一般用到的不多,不过平时用javap -c比较多,该命令用于列出每个方法所执行的JVM指令,用来解决比较棘手的逻辑出错的bug是个不错的选择。另外通过字节码和源代码的对比,深入分析java的编译原理及代码执行过程,解决各种Java原理级别的问题。

转载地址:http://bjwlo.baihongyu.com/

你可能感兴趣的文章
麻省理工研究人员在比特币闪电网络上测试Oracle和智能合约
查看>>
两面看问题:区块链与伦理人权
查看>>
微软宣布支持基于虚拟机的Azure IOT Edge服务
查看>>
AI+社交,快手商业化落地之道
查看>>
在Azure平台上开发物联网方案的最佳实践
查看>>
[leetcode] 435.Non-overlapping Intervals
查看>>
动态横竖屏切换KSYLive_iOS
查看>>
springboot的metrics
查看>>
开发移动端react组件datepicker的总结与教训
查看>>
简单的内存缓存模块 - Smache
查看>>
gulp前端构建工具白话讲解,也包含自己使用的一些心得体会 。(针对初次接触gulp的同学,大神误喷)...
查看>>
最新超详细linux部署wordpress步骤
查看>>
独孤九剑(0x02) - 数据结构篇
查看>>
【译】 eBay 的速度与风范
查看>>
Android 优化交互 —— CoordinatorLayout 与 Behavior
查看>>
[LintCode/LeetCode] Generate Parentheses
查看>>
Comparable and Comparator
查看>>
Javascript---Date类型和Math类型
查看>>
从ACID到CAP到BASE
查看>>
一种Auto Unlock的方法
查看>>