重复 .ajax 调用导致 jQuery 内存泄漏

标签 jquery firefox memory-leaks

我使用的以下模式在 Firefox 中会泄漏内存:

$(function() {

    (function() {

        var callee = arguments.callee;

        $.ajax({
            url: '...',
            success: function() { ... setTimeout(callee, 1000); },
            error: function() { ... setTimeout(callee, 1000); }
        });

    })();

});

即使成功/错误除了再次调用 setTimeout 之外什么也不做,内存泄漏仍然存在。我正在通过 Windows 任务管理器观察泄漏;如果页面保持打开状态,firefox.exe 的内存使用量会慢慢增加。对于此代码的最终版本,我只需要每分钟更新一次,但每秒更新一次会更快地演示内存泄漏!

(注意:这看起来与 this question 非常相似,但所选答案似乎不适合 Firefox)

最佳答案

我能够重现该问题并解决它:

$(function() 
{
    function checkStatus() 
    {
        $.ajax({
          url: '...',
          success: function() { ... setTimeout(checkStatus, 1000); },
          error: function() { ... setTimeout(checkStatus, 1000); }
        });

    }

    checkStatus();

});

似乎发生的情况是每次调用匿名方法时,它都会创建一个变量并为其分配一个引用。如果有足够的时间,这将填满内存。

此解决方案只是传递相同的函数引用,而不是在每次迭代时创建一个新函数引用。

关于重复 .ajax 调用导致 jQuery 内存泄漏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3617442/

相关文章:

jquery - jQuery 中的按键事件

javascript - 为什么这个字符串会变成完整的元素选择器?

javascript - 我如何告诉 jQuery 忽略空的服务器响应?

c++ - 在 malloc_error_break 中设置断点以在 C++ 中进行调试

jquery - $(document).ready 和 $(document).on ('pageinit' 之间的区别)

jquery - 可以让动画背景变白并覆盖其他图像

css - FireFox 特定的 CSS

html - Mozilla Firefox 无法显示网站

android - 需要帮助了解我的 Android 应用程序中的内存泄漏

c++ - 无效的堆参数 : allocated with operator new[], 通过运算符(operator)删除释放