java.lang.OutOfMemoryError: Java heap space
在java程序運(yùn)行中可能會(huì)報(bào)如上的錯(cuò)誤,通常是在運(yùn)行過(guò)程中內(nèi)存占用了沒(méi)有別釋放造成的。
以前可能沒(méi)法跟蹤可能是很痛苦的事情,現(xiàn)在好了,我們有一個(gè)調(diào)試軟件可以用了,在生產(chǎn)環(huán)境下使用的jRockit軟件進(jìn)行調(diào)試,是oracle公司出品的。
前兩天試用了一下真的很不錯(cuò)。
前陣子有個(gè)程序跑2個(gè)禮拜左右就會(huì)堆棧溢出,始終找不到頭緒,后來(lái)使用jrockit才找到問(wèn)題的出處。
jrockit是可以調(diào)試遠(yuǎn)程程序也可以調(diào)試本地程序的。
具體調(diào)試步驟
(一)
?
如果是調(diào)試本地程序的話(huà),啟動(dòng)jrockit,然后啟動(dòng)本地需要調(diào)試的程序,會(huì)在左側(cè)工具欄 本地目錄下創(chuàng)建一個(gè)連接為需要調(diào)試的程序,在上面點(diǎn)擊右鍵,就會(huì)啟動(dòng)跟蹤。
如何跟蹤呢,我的辦法就是等,在跟蹤開(kāi)始后,進(jìn)行截圖,然后等程序運(yùn)行一段時(shí)間后查找堆增長(zhǎng)比較大的并且一直沒(méi)有釋放的變量。
(二)
然后在上面點(diǎn)擊右鍵,顯示分配跟蹤。
(三)
然后找到對(duì)應(yīng)的方法,然后就去找問(wèn)題吧,看看是不是那個(gè)地方有內(nèi)存一直沒(méi)有釋放啊。
?
然后說(shuō)點(diǎn)我自己的小經(jīng)驗(yàn),也許是不對(duì)的,但是我在我的應(yīng)用里面確實(shí)是有效的。
?
在經(jīng)常需要調(diào)用的地方將變量設(shè)成全局的甚至是靜態(tài)的,我的操作是設(shè)成全局的了。圖省事呢。呵呵,因?yàn)槲业淖兞繒r(shí)全局都要調(diào)用的而且是頻繁調(diào)用的。
用完的變量一定要記得讓它等于null,否則執(zhí)行g(shù)c()貌似是不給回收的。
基本上jrockit跟蹤是很強(qiáng)的,都能夠找到你的問(wèn)題所在,要仔細(xì)觀察,改完程序后記得再重新跟蹤下直到?jīng)]有內(nèi)存泄露為止。
寫(xiě)完手工。
題外話(huà),寫(xiě)多線(xiàn)程的時(shí)候建議使用線(xiàn)程池來(lái)操作。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

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