使用java自帶的性能分析工具jvisualvm , 可以方便的查看內(nèi)存, 對(duì)象, 線程等多種信息.
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供高陽(yáng)網(wǎng)站建設(shè)、高陽(yáng)做網(wǎng)站、高陽(yáng)網(wǎng)站設(shè)計(jì)、高陽(yáng)網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、高陽(yáng)企業(yè)網(wǎng)站模板建站服務(wù),10多年高陽(yáng)做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
win+R????然后輸入???jvisualvm??回車即可
效果如下圖
你可以先用內(nèi)存監(jiān)控工具,進(jìn)行監(jiān)控,看看這個(gè)功能到底用多少內(nèi)存。如果不多,其實(shí)都不需要實(shí)現(xiàn)你說的代碼監(jiān)控的。如果你要使用代碼監(jiān)控,你可是使用Runtime類的幾個(gè)屬性,MaxMemory、FreeMemory、TotalMemory。然后實(shí)現(xiàn)個(gè)線程,在下載pdf功能前開啟線程,然后完畢時(shí)關(guān)閉線程,如果內(nèi)存即將溢出(設(shè)定個(gè)閾值,比如說15%),就報(bào)錯(cuò),跳轉(zhuǎn)到錯(cuò)誤頁(yè)面。
要定位到行,代碼要debug編譯,至少要帶上行信息。
線程占用內(nèi)存高低,可以用jmap做heap dump出來給MomoryAnalysis分析他可以按線程統(tǒng)計(jì),一般也可以用它來找出造成OOM的原因。
線程占用CPU,上述內(nèi)存的問題是一個(gè)方面,另外也可以jstack打線程棧來分析。Linux上ps -T -p可以看底層線程的CPU占用(Windows上需要額外按工具),記得線程編號(hào)可以在jstack打出來的線程棧中檢查。