原文:http://www.csdn.net/article/2014-11-20/2822750-5-JDK-Tools-Every-Java-Developer-Should-Know?reload=1
每個Java開發者都應該知道的5個JDK工具
【編者按】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
- }
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.uptimeVM.uptime顯示了Java應用程序具體運行時間。
3344:289.977 s
在調試的時候,下面的參數可以用於併發鎖的線程堆棧溢出。
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/查看堆內存柱狀圖。
作爲JVM融合戰略的一部分,主要用來統一HotSpot、JRockit VMs。目前,JRockit Mission Control在標準版Java SE中已經可以使用。Java Mission Control(JMC)與Java Flight Recorder一起工作,適用於HotSpot JVM,用來記錄核心數據和事件。它是一個調優工具,並且適用於Oracle JDK。一旦出現問題,這些數據就可以用來分析。
開發者可以使用jmc命令來創建JMC工具。
來自: javapapers
本文爲CSDN編譯整理,未經允許不得轉載,如需轉載請聯繫market#csdn.net(#換成@)