深度理解java jvm,深度理解JVM
深入理解java虛擬機(jī)
要講的內(nèi)容
了解歷史
垃圾回收機(jī)制
性能監(jiān)控工具
性能調(diào)優(yōu)案例實(shí)戰(zhàn)
認(rèn)識(shí)類的文件結(jié)構(gòu)
類加載機(jī)制
字節(jié)碼執(zhí)行引擎
虛擬機(jī)編譯及運(yùn)行時(shí)優(yōu)化
Java線程高級(jí)
1.?環(huán)境搭建
安裝jdk
2.?內(nèi)存溢出場(chǎng)景模擬
public class Test01 {
public static void main(String[] args) {
//測(cè)試內(nèi)存溢出
List list = new ArrayList();
while(true) {
list.add(new Demo());
}
//不停的創(chuàng)建對(duì)象會(huì)一直消耗堆內(nèi)存知道內(nèi)存消耗完(其實(shí)不會(huì)真的將8G的內(nèi)存都消耗完)
//當(dāng)達(dá)到一個(gè)上線時(shí)就會(huì)報(bào)出這個(gè)錯(cuò)誤了,這時(shí)就會(huì)報(bào)出一個(gè)內(nèi)存溢出
//OutOfMemoryError
}
}
class Demo{
}
可以在你的項(xiàng)目下找到這個(gè)快照的錯(cuò)誤文件
但是我們是看不懂的所以需要到http://www.eclipse.org/mat/downloads.php去下載一個(gè)eclipse的MemoryAnalyzer分析工具
如果你直接下載會(huì)非常慢所以選擇一個(gè)其他的鏡像這樣下載就會(huì)快點(diǎn)
下載解壓后打開
點(diǎn)擊file->Open Heap Dump 選中產(chǎn)生的那個(gè)文件
然后生成一個(gè)
選中這個(gè)圖標(biāo)可以查看我們的堆內(nèi)存運(yùn)行情況 加載堆內(nèi)存的信息
這個(gè)就代表很可能在main里面出現(xiàn)問題了 占得百分比高達(dá)95.6%
Shallow Heap 對(duì)象本分所占用的內(nèi)存大小不包含它的引用對(duì)象
Retained Heap 代表當(dāng)前對(duì)象的大小包括當(dāng)前可直接或者間接引用對(duì)象的大小的總和。
點(diǎn)開那個(gè)占用堆內(nèi)存最多線程
繼續(xù)點(diǎn)開會(huì)發(fā)現(xiàn) 他創(chuàng)建了很多個(gè)這樣的對(duì)象造成的堆內(nèi)存溢出
Jvm 的可視化監(jiān)控工具
這個(gè)工具在哪呢在我們安裝的jdk中
因?yàn)槲覀兊膉dk已經(jīng)配置在我們的path路徑下因此在任何路徑下都可以訪問的到所以在
命令行中可以輸入這個(gè)值 會(huì)將這個(gè)可視化界面彈出來
我們可以看到這個(gè)圖像化界面只有18k那么真正的代碼放在了lib目錄下的一個(gè)jar包里面
這個(gè)jps這個(gè)命令會(huì)列出來所有的java進(jìn)程,我們看到有JConsole 這個(gè)進(jìn)程 但是為什么沒有jps這個(gè)進(jìn)程呢是因?yàn)?/p>
這個(gè)命令執(zhí)行完之后就結(jié)束了。
當(dāng)我們點(diǎn)進(jìn)去就能對(duì)這個(gè)進(jìn)程進(jìn)行監(jiān)控
我們大概就能看到這樣的窗口了
Java 之父
詹姆斯 ?高林斯
標(biāo)簽:這個(gè),JVM,jdk,理解,內(nèi)存,Heap,深度,我們,溢出
來源: https://www.cnblogs.com/zhulina-917/p/11387900.html
總結(jié)
以上是生活随笔為你收集整理的深度理解java jvm,深度理解JVM的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python常用的库有哪些餐厅_这十个P
- 下一篇: 仅完成部分的readprocessmem