Java DWR內(nèi)存泄漏問題解決方案
機(jī)器跑了一晚上,發(fā)現(xiàn)有崩潰現(xiàn)象,由于頁面內(nèi)有動(dòng)態(tài)繪圖功能,我懷疑是繪圖原因,但是今天上午有人提醒我才想到,是不是間隔調(diào)用時(shí)DWR產(chǎn)生了內(nèi)存泄漏問題?
網(wǎng)上查了一下貌似大家都在討論這個(gè)問題,之前我也挺老手說過DWR有內(nèi)存問題,可是沒有遇到過。原來DWR在間隔調(diào)用這種情況下會(huì)有問題!
按照大家的說法,修改engine.js配置文件來解決問題,目前我也修改了一下,修改方法如下:
在
dwr.engine._sendData = function(batch) {}
內(nèi)有,這樣幾行代碼:
// Get setup for XMLHttpRequest if possibleif (batch.rpcType == dwr.engine.XMLHttpRequest) {if (window.XMLHttpRequest) { batch.req = new XMLHttpRequest();}// IE5 for the mac claims to support window.ActiveXObject, but throws an error when it’s usedelse if (window.ActiveXObject && !(navigator.userAgent.indexOf('Mac') >= 0 && navigator.userAgent.indexOf('MSIE') >= 0)) { batch.req = dwr.engine._newActiveXObject(dwr.engine._XMLHTTP);}}
看起來IE請(qǐng)求Ajax的對(duì)象每次都在創(chuàng)建
而根據(jù)網(wǎng)上的說法,IE在創(chuàng)建對(duì)象后,如果這個(gè)頁面不關(guān)閉(包括不能最小化)時(shí),其創(chuàng)建的對(duì)象是一直不銷毀的。那么無限制的創(chuàng)建對(duì)象且不銷毀,當(dāng)然會(huì)內(nèi)存泄漏
目前我改了一下,如下面代碼:
var httprequest = null;// Get setup for XMLHttpRequest if possibleif(null==httprequest){// Get setup for XMLHttpRequest if possibleif (batch.rpcType == dwr.engine.XMLHttpRequest) {if (window.XMLHttpRequest) {httprequest = new XMLHttpRequest();}// IE5 for the mac claims to support window.ActiveXObject, but throws an error when it’s usedelse if (window.ActiveXObject && !(navigator.userAgent.indexOf('Mac') >= 0 && navigator.userAgent.indexOf('MSIE') >= 0)) {httprequest = dwr.engine._newActiveXObject(dwr.engine._XMLHTTP);}}}
就是說第一次創(chuàng)建,之后不再創(chuàng)建,相當(dāng)于單例模式。
由于內(nèi)存泄漏時(shí)長時(shí)間運(yùn)行引起的,目前尚不知該方法是否能解決問題。但是從任務(wù)管理器上看,好像有所改善,我們還需要進(jìn)一步測試。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 基于android studio的layout的xml文件的創(chuàng)建方式2. 解決Android studio xml界面無法預(yù)覽問題3. 詳解Android studio 動(dòng)態(tài)fragment的用法4. 圖文詳解vue中proto文件的函數(shù)調(diào)用5. 什么是python的自省6. Spring Boot和Thymeleaf整合結(jié)合JPA實(shí)現(xiàn)分頁效果(實(shí)例代碼)7. Android如何加載Base64編碼格式圖片8. 使用Android studio查看Kotlin的字節(jié)碼教程9. Vuex localStorage的具體使用10. Vue封裝一個(gè)TodoList的案例與瀏覽器本地緩存的應(yīng)用實(shí)現(xiàn)

網(wǎng)公網(wǎng)安備