JDK是Java語言的軟件開發(fā)工具包,沒有它就無法編譯Java程序。目前,有許許多多的JDK工具呈現(xiàn)在大家面前,但最常用的莫過于java.exe、javac.exe、jar等。除了這幾個,還有哪些呢?本文作者Joe擁有多年的Java開發(fā)經(jīng)驗,其在博客上分享了一篇文章:
5 JDK Tools Every Java Developer Should Know
,筆者對其進行了編譯,以下為譯文。?
目前,有許多工具可以綁定到Java JDK上面,其中java.exe和javac.exe是每位Java工程師的必 備武器,與此同時,還有許多其它Java JDK工具呈現(xiàn)在大家眼前。大多數(shù)Java程序員都沒有使用過這些工具,但如果使用,它們會讓你的工作事半功倍。?
在之前的教程中,我曾介紹過?
這些工具
。現(xiàn)在,我向大家介紹其中最重要的5個工具。?
1.
javap
?
javap是一個Java類文件反匯編程序,可以查看Java編譯器生成的字節(jié)碼,是分析代碼的一個好工具。讓我們用javap來編譯這段Hello World代碼,再分解它。?
- public ? class ?HelloWorld?{????
- ???? public ? static ? void ?main(String...?args)?{????
- ????????System.out.println( "Hello?World!" );????
- ????}????
- }???
?
我沒有傳遞任何參數(shù),只是運行了javap這個工具,就得到了上面這個結(jié)果。默認(rèn)情況下,它會輸出Java類的package,protected,public字段和方法。?
- Compiled?from? "HelloWorld.java" ????
- public ? class ?HelloWorld?{????
- ?? public ?HelloWorld();????
- ?? public ? static ? void ?main(java.lang.String...);????
- }????
?
如果傳遞參數(shù)-c到j(luò)avap里面,便會得到上面這個結(jié)果。這是一條非常好的信息,這樣輸出的指令可以幫助我們更好地了解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虛擬機監(jiān)控和分析工具,該工具提供了一個圖形界面窗口,并且可以直觀的了解Java應(yīng)用程序的運行時信息。jvisualvm集成了許多工具,比如像jmp、jinfo、jstat、jstack、JConsole等。自從JDK 6 Update 7以后已經(jīng)作為JDK的一部分。?
在?
Java垃圾回收監(jiān)控和分析
這篇文章中,我曾使用jvisualvm,大家不妨過去看看jvisualvm的使用方法。?
3.
jcmd
?
jcmd主要用來把診斷命令請求發(fā)送到Java JVM中,當(dāng)JVM進程中沒有jcmd參數(shù)列表時,jcmd就會立即運行。這相當(dāng)于jps工具,我開始啟動jconsole,并且把它作為參數(shù)傳遞到j(luò)cmd,得到如下結(jié)果,這個也可以通過進程id(pid)實現(xiàn)。?
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
3344:289.977 s
VM.uptime顯示了Java應(yīng)用程序具體運行時間。?
在調(diào)試的時候,下面的參數(shù)可以用于并發(fā)鎖的線程堆棧溢出。?
4.jhat?
jhat的全稱是Java heap analysis tool。它主要是用來解析和瀏覽堆文件,jhat有時更像是一個可視化工具。jhat解析堆存儲( heap dump)并啟動一個webserver,然后用戶可以在瀏覽器下查看堆。jhat支持對象查詢語言(oql)和一些預(yù)先設(shè)計查詢。OQL幫助可能在?
jmap工具來生成堆轉(zhuǎn)儲,我們應(yīng)該使用-dump參數(shù),下面jhat工具可以使用的參數(shù)列表:?
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應(yīng)用程序創(chuàng)建了一個堆轉(zhuǎn)儲文件,并使用以下命令來運行進程id 3344:?
現(xiàn)在,堆轉(zhuǎn)儲文件準(zhǔn)備就緒,運行下面命令并且會啟動一個服務(wù):?
在控制臺輸出結(jié)果:?
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/后便會出來堆轉(zhuǎn)儲的詳細(xì)情況:?
例如,還可以在http://localhost:7000/histo/查看堆內(nèi)存柱狀圖。?
5.
Oracle Java Mission Control
?
作為JVM融合戰(zhàn)略的一部分,主要用來統(tǒng)一HotSpot、JRockit VMs。目前,JRockit Mission Control在標(biāo)準(zhǔn)版Java SE中已經(jīng)可以使用。Java Mission Control(JMC)與Java Flight Recorder一起工作,適用于HotSpot JVM,用來記錄核心數(shù)據(jù)和事件。它是一個調(diào)優(yōu)工具,并且適用于Oracle JDK。一旦出現(xiàn)問題,這些數(shù)據(jù)就可以用來分析。?
開發(fā)者可以使用jmc命令來創(chuàng)建JMC工具。?
?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
