DWR內(nèi)存兼容及無法調(diào)用問題解決方案
在上次遇到DWR內(nèi)存泄漏問題后根據(jù)網(wǎng)上的內(nèi)容對JS文件進行修改,修改后發(fā)現(xiàn)還有一些兼容的問題,同時還出現(xiàn)不能調(diào)用的一些情況。
而且根據(jù)統(tǒng)計DWR就算內(nèi)存泄漏,也不是特別嚴重,除非你一個瀏覽器跑幾天不關(guān)閉,而且實時刷新!
經(jīng)過再次查詢,得知IE瀏覽器有自己的一個垃圾回收的函數(shù):CollectGarbage();
CollectGarbage,是IE的一個特有屬性,用于釋放內(nèi)存的使用方法嘛應該是,將該變量或引用對象,設置為null或delete
然后在進行釋放動作在做CollectGarbage前,要必需清楚的兩個必備條件:
引用
- 一個對象在其生存的上下文環(huán)境之外,即會失效。
- 一個全局的對象在沒有被執(zhí)用(引用)的情況下,即會失效。
對于對象何時失效,有這樣的一些解釋:
function testObject() { var _obj1 = new Object(); } function testObject2() { var _obj2 = new Object(); return _obj2; } // 示例1 testObject(); // 示例2 testObject2() // 示例3 var obj3 = testObject2(); obj3 = null; // 示例4 var obj4 = testObject2(); var arr = [obj4]; obj3 = null; arr = [];
在這四個示例中:
- “示例1”在函數(shù)testObject()中構(gòu)造了_obj1,但是在函數(shù)退出時,它就已經(jīng)離開了函數(shù)的上下文環(huán)境,因此_obj1失效了;
- “示例2”中,testObject2()中也構(gòu)造了一個對象_obj2并傳出,因此對象有了“函數(shù)外”的上下文環(huán)境(和生存周期),然而由于函數(shù)
的返回值沒有被其它變量“持有”,因此_obj2也立即失效了;
- “示例3”中,testObject2()構(gòu)造的_obj2被外部的變量obj3持用了,這時,直到“obj3=null”這行代碼生效時,_obj2才會因為引用關(guān)系消失而失效。
- 與示例3相同的原因,“示例4”中的_obj2會在“arr=[]”這行代碼之后才會失效。
另外我發(fā)現(xiàn)許多人都說了這樣一句話:
最后之最后,關(guān)于GC的一個補充說明:在IE窗體被最小化時,IE將會主動調(diào)用一次CollectGarbage()函數(shù)。這使得IE窗口在最小化之后,內(nèi)存占用會有明顯改善。
我只能說,調(diào)用CollectGarbage()函數(shù)會有意外的收獲,但是他不是萬能的,也不是調(diào)用就能釋放內(nèi)存更不是說調(diào)用后和將瀏覽器最小化一次的效果一樣。
我們是每秒五次刷新,每次刷新點有一百多處,這樣瀏覽器的DOM始終是在增加和更新東西。算下來,就是跑一個小時也是有很大消耗的。
更何況我們的軟件要跑在一個定制的機器上,發(fā)現(xiàn)這個機器的硬件有兼容問題,我們將瀏覽器更新到IE7.0,進行數(shù)據(jù)實時刷新后發(fā)現(xiàn),內(nèi)存一直增長,直到瀏覽器崩潰。但是不同機器崩潰的時機不同。
我在每次更新后調(diào)用垃圾回收函數(shù),發(fā)現(xiàn)瀏覽器的內(nèi)存仍在增加,但是間隔的有增有加,雖然總體還是在增加。由此,我們在那個機器上跑了十幾個小時,瀏覽器內(nèi)存沒有超過50M。
很少有那個頁面會這樣大量的刷新,并跑這么長時間吧,可是我們遇到了。
把問題歸咎與DWR我發(fā)現(xiàn)不是很合理,至少現(xiàn)在我這么覺得,但是對于頁面有大量刷新和需要長時間運行這個需求來說,我覺得還是需要深入研究一下的。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
js unicode 編碼解析關(guān)于數(shù)據(jù)轉(zhuǎn)換為中文的兩種方法
這篇文章主要介紹了js unicode 編碼解析關(guān)于數(shù)據(jù)轉(zhuǎn)換為中文的兩種方法,需要的朋友可以參考下2014-04-04關(guān)于預加載InstantClick的問題解決方法
本篇文章主要介紹了關(guān)于預加載InstantClick的問題解決方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09JavaScript中判斷為整數(shù)的多種方式及保留兩位小數(shù)的方法
這篇文章主要介紹了JavaScript中判斷為整數(shù)的多種方式,以及保留兩位小數(shù)的方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09axios使用攔截器統(tǒng)一處理所有的http請求的方法
這篇文章主要介紹了axios使用攔截器統(tǒng)一處理所有的http請求的方法,通過一段實例代碼給大家介紹了axios攔截器使用,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-11-11