每個Java開發者都應該知道的5個JDK工具

CSDN發表於2014-12-18

JDK是Java語言的軟體開發工具包,沒有它就無法編譯Java程式。目前,有許許多多的JDK工具呈現在大家面前,但最常用的莫過於java.exe、javac.exe、jar等。除了這幾個,還有哪些呢?本文作者Joe擁有多年的Java開發經驗,其在部落格上分享了一篇文章:5 JDK Tools Every Java Developer Should Know,筆者對其進行了編譯,以下為譯文。

目前,有許多工具可以繫結到Java JDK上面,其中java.exe和javac.exe是每位Java工程師的必 備武器,與此同時,還有許多其它Java JDK工具呈現在大家眼前。大多數Java程式設計師都沒有使用過這些工具,但如果使用,它們會讓你的工作事半功倍。

在之前的教程中,我曾介紹過 這些工具。現在,我向大家介紹其中最重要的5個工具。

1.javap

javap是一個Java類檔案反彙編程式,可以檢視Java編譯器生成的位元組碼,是分析程式碼的一個好工具。讓我們用javap來編譯這段Hello World程式碼,再分解它。

public class HelloWorld {
    public static void main(String... args) {
        System.out.println("Hello World!");
    }
}

C:\Users\Cycle\Desktop>javap HelloWorld

我沒有傳遞任何引數,只是執行了javap這個工具,就得到了上面這個結果。預設情況下,它會輸出Java類的package,protected,public欄位和方法。

Compiled from "HelloWorld.java"
public class HelloWorld {
  public HelloWorld();
  public static void main(java.lang.String...);
}

C:\Users\Cycle\Desktop>javap -c HelloWorld

如果傳遞引數-c到javap裡面,便會得到上面這個結果。這是一條非常好的資訊,這樣輸出的指令可以幫助我們更好地瞭解JVM。

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

  public static void main(java.lang.String...);
    Code:
       0: getstatic     #2                  // Field java/lang/System.out:Ljava/io/PrintStream;
       3: ldc           #3                  // String Hello World!
       5: invokevirtual #4                  // Method java/io/PrintStream.println:(Ljava/lang/String;)V
       8: return
}

2.jvisualvm

jvisualvm是一個Java虛擬機器監控和分析工具,該工具提供了一個圖形介面視窗,並且可以直觀的瞭解Java應用程式的執行時資訊。jvisualvm整合了許多工具,比如像jmp、jinfo、jstat、jstack、JConsole等。自從JDK 6 Update 7以後已經作為JDK的一部分。

在 Java垃圾回收監控和分析這篇文章中,我曾使用jvisualvm,大家不妨過去看看jvisualvm的使用方法。

3.jcmd

jcmd主要用來把診斷命令請求傳送到Java JVM中,當JVM程式中沒有jcmd引數列表時,jcmd就會立即執行。這相當於jps工具,我開始啟動jconsole,並且把它作為引數傳遞到jcmd,得到如下結果,這個也可以通過程式id(pid)實現。

C:\Users\Cycle>jconsole

C:\Users\Cycle>jcmd JConsole help
3344:
The following commands are available:
JFR.stop
JFR.start
JFR.dump
JFR.check
VM.native_memory
VM.check_commercial_features
VM.unlock_commercial_features
ManagementAgent.stop
ManagementAgent.start_local
ManagementAgent.start
Thread.print
GC.class_stats
GC.class_histogram
GC.heap_dump
GC.run_finalization
GC.run
VM.uptime
VM.flags
VM.system_properties
VM.command_line
VM.version
help

C:\Users\Cycle>jcmd JConsole VM.uptime
3344:289.977 s

VM.uptime顯示了Java應用程式具體執行時間。

在除錯的時候,下面的引數可以用於併發鎖的執行緒堆疊溢位。

jcmd <pid> Thread.print -l

4.jhat

jhat的全稱是Java heap analysis tool。它主要是用來解析和瀏覽堆檔案,jhat有時更像是一個視覺化工具。jhat解析堆儲存( heap dump)並啟動一個webserver,然後使用者可以在瀏覽器下檢視堆。jhat支援物件查詢語言(oql)和一些預先設計查詢。OQL幫助可能在

http://localhost:7000/oql/

http://localhost:7000/oqlhelp/

jmap工具來生成堆轉儲,我們應該使用-dump引數,下面jhat工具可以使用的引數列表:

C:\Users\Cycle>jhat -help
Usage:  jhat [-stack ] [-refs ] [-port ] [-baseline ] [-debug ] [-version] [-h|-help] 

        -J          Pass  directly to the runtime system. For
                          example, -J-mx512m to use a maximum heap size of 512MB
        -stack false:     Turn off tracking object allocation call stack.
        -refs false:      Turn off tracking of references to objects
        -port :     Set the port for the HTTP server.  Defaults to 7000
        -exclude :  Specify a file that lists data members that should
                          be excluded from the reachableFrom query.
        -baseline : Specify a baseline object dump.  Objects in
                          both heap dumps with the same ID and same class will
                          be marked as not being "new".
        -debug :     Set debug level.
                            0:  No debug output
                            1:  Debug hprof file parsing
                            2:  Debug hprof file parsing, no server
        -version          Report version number
        -h|-help          Print this help and exit
                    The file to read

For a dump file that contains multiple heap dumps,
you may specify which dump in the file
by appending "#" to the file name, i.e. "foo.hprof#3".

All boolean options default to "true"

我給jconsole應用程式建立了一個堆轉儲檔案,並使用以下命令來執行程式id 3344:

jmap -dump:format=b,file=heap.bin 3344

現在,堆轉儲檔案準備就緒,執行下面命令並且會啟動一個服務:

jmap -dump:format=b,file=heap.bin 3344

在控制檯輸出結果:

C:\Users\Cycle\Desktop>jhat heap.bin
Reading from heap.bin...
Dump file created Sun Nov 16 19:26:35 IST 2014
Snapshot read, resolving...
Resolving 641209 objects...
Chasing references, expect 128 dots..................
Eliminating duplicate references.....................
Snapshot resolved.
Started HTTP server on port 7000
Server is ready.

在瀏覽器中輸入:http://localhost:7000/後便會出來堆轉儲的詳細情況:

例如,還可以在http://localhost:7000/histo/檢視堆記憶體柱狀圖。

5.Oracle Java Mission Control

作為JVM融合戰略的一部分,主要用來統一HotSpot、JRockit VMs。目前,JRockit Mission Control在標準版Java SE中已經可以使用。Java Mission Control(JMC)與Java Flight Recorder一起工作,適用於HotSpot JVM,用來記錄核心資料和事件。它是一個調優工具,並且適用於Oracle JDK。一旦出現問題,這些資料就可以用來分析。

開發者可以使用jmc命令來建立JMC工具。

相關文章