欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javap命令的使用技巧

 更新時(shí)間:2018年05月02日 14:06:59   投稿:laozhang  
本篇文章給大家分享了關(guān)于JAVA中關(guān)于javap命令的使用技巧以及相關(guān)代碼分享,有需要的朋友參考學(xué)習(xí)下。

avap是jdk自帶的一個(gè)工具在jdk安裝目錄的/bin下面可以找到,可以對(duì)代碼反編譯,也可以查看java編譯器生成的字節(jié)碼,對(duì)代碼的執(zhí)行過(guò)程進(jìn)行分析,了解jvm內(nèi)部的工作。

下面列舉javap命令的常用options及其功能描述,更多功能的使用請(qǐng)自行Google,樓主不做贅述。

用法摘要

-help 幫助
-l 輸出行和變量的表
-public 只輸出public方法和域
-protected 只輸出public和protected類和成員
-package 只輸出包,public和protected類和成員,這是默認(rèn)的
-p -private 輸出所有類和成員
-s 輸出內(nèi)部類型簽名
-c 輸出分解后的代碼,例如,類中每一個(gè)方法內(nèi),包含java字節(jié)碼的指令,
-verbose 輸出棧大小,方法參數(shù)的個(gè)數(shù)
-constants 輸出靜態(tài)final常量

實(shí)例分析

javap命令分解一個(gè)class文件,它根據(jù)options來(lái)決定到底輸出什么。如果沒有使用options,那么javap將會(huì)輸出該class文件中的包,類里的protected和public域以及類里的所有方法。javap將會(huì)把它們輸出在標(biāo)準(zhǔn)輸出上。來(lái)看這個(gè)例子,先編譯(javac)下面這個(gè)類。

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<String, String> producer = new KafkaProducer<>(props);
 for(int i = 0; i < 100; i++) {
  producer.send(new ProducerRecord<String, String>("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<String, String> consumer = new KafkaConsumer<>(props);
 consumer.subscribe(Arrays.asList("my-topic"));

 while (true) {
  ConsumerRecords<String, String> records = consumer.poll(100);
  for (ConsumerRecord<String, String> 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后,輸出結(jié)果如下

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[]);
}

結(jié)合代碼分析編譯器執(zhí)行過(guò)程

這里只關(guān)注main方法內(nèi)部的代碼邏輯,main方法代碼如下

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

在命令行上鍵入javap -c KafkaTest后,輸出結(jié)果如下

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 分別代表定義兩個(gè)普通變量,iload_1 , iload_2 分別表示加載istore_1,istore_2 兩個(gè)變量到數(shù)據(jù)棧中,imul表示兩個(gè)變量做乘法運(yùn)算,結(jié)果賦值給變量istore_3,最后將結(jié)果輸出,程序返回。

在分析這段簡(jiǎn)單代碼的過(guò)程中,樓主發(fā)現(xiàn)了一個(gè)jvm編譯命令的網(wǎng)站,分享出來(lái)jvm指令。

總結(jié)

樓主在上面做了一個(gè)簡(jiǎn)單的代碼分析的過(guò)程,希望可以幫助到有緣人。javap可以用于反編譯和查看編譯器編譯后的字節(jié)碼。一般用到的不多,不過(guò)平時(shí)用javap -c比較多,該命令用于列出每個(gè)方法所執(zhí)行的JVM指令,用來(lái)解決比較棘手的邏輯出錯(cuò)的bug是個(gè)不錯(cuò)的選擇。另外通過(guò)字節(jié)碼和源代碼的對(duì)比,深入分析java的編譯原理及代碼執(zhí)行過(guò)程,解決各種Java原理級(jí)別的問題。

相關(guān)文章

  • IDEA中實(shí)現(xiàn)springboot熱部署方式

    IDEA中實(shí)現(xiàn)springboot熱部署方式

    在IDEA中實(shí)現(xiàn)SpringBoot的熱部署可以通過(guò)修改設(shè)置來(lái)完成,首先在設(shè)置中搜索Compiler,并勾選Build project automatically,然后進(jìn)入Advanced Settings,勾選Allow auto-make to start even if developed application is currently running
    2024-09-09
  • 基于Java SSM框架實(shí)現(xiàn)簡(jiǎn)易的評(píng)教系統(tǒng)

    基于Java SSM框架實(shí)現(xiàn)簡(jiǎn)易的評(píng)教系統(tǒng)

    這篇文章主要介紹了通過(guò)Java SSM框架實(shí)現(xiàn)一個(gè)簡(jiǎn)易的評(píng)教系統(tǒng)的示例代碼,文中的代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-02-02
  • 淺談controller中調(diào)用多個(gè)service方法的問題

    淺談controller中調(diào)用多個(gè)service方法的問題

    這篇文章主要介紹了淺談controller中調(diào)用多個(gè)service方法的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • IntelliJ Idea 2017注冊(cè)碼免費(fèi)激活方法

    IntelliJ Idea 2017注冊(cè)碼免費(fèi)激活方法

    IDEA 全稱 IntelliJ IDEA,是Java語(yǔ)言開發(fā)的集成環(huán)境,IntelliJ在業(yè)界被公認(rèn)為最好的java開發(fā)工具之一。下面給大家介紹IntelliJ Idea 2017注冊(cè)碼免費(fèi)激活方法,需要的朋友參考下
    2018-01-01
  • 解決springboot報(bào)錯(cuò)Could not resolve placeholder‘xxx‘ in value“${XXXX}

    解決springboot報(bào)錯(cuò)Could not resolve placeholder‘x

    這篇文章主要介紹了解決springboot報(bào)錯(cuò):Could not resolve placeholder ‘xxx‘ in value “${XXXX}問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • 簡(jiǎn)單分析Java線程編程中ThreadLocal類的使用

    簡(jiǎn)單分析Java線程編程中ThreadLocal類的使用

    這篇文章主要介紹了Java線程編程中ThreadLocal類的使用,包括使用其對(duì)共享變量的操作的分析,需要的朋友可以參考下
    2015-12-12
  • BigDecimal divide除法除不盡報(bào)錯(cuò)的問題及解決

    BigDecimal divide除法除不盡報(bào)錯(cuò)的問題及解決

    這篇文章主要介紹了BigDecimal divide除法除不盡報(bào)錯(cuò)的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 5分鐘讓你快速掌握java8 stream常用開發(fā)技巧

    5分鐘讓你快速掌握java8 stream常用開發(fā)技巧

    這篇文章主要給大家介紹了關(guān)于java8 stream常用開發(fā)技巧的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Java并發(fā)工具類Phaser詳解

    Java并發(fā)工具類Phaser詳解

    這篇文章主要介紹了Java并發(fā)工具類Phaser詳解,Phaser(階段協(xié)同器)是一個(gè)Java實(shí)現(xiàn)的并發(fā)工具類,用于協(xié)調(diào)多個(gè)線程的執(zhí)行,它提供了一些方便的方法來(lái)管理多個(gè)階段的執(zhí)行,可以讓程序員靈活地控制線程的執(zhí)行順序和階段性的執(zhí)行,需要的朋友可以參考下
    2023-11-11
  • Java反射機(jī)制的精髓講解

    Java反射機(jī)制的精髓講解

    今天小編就為大家分享一篇關(guān)于Java反射機(jī)制的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01

最新評(píng)論