寻求有关使用承诺的nodejs专家的帮助.我有以下测试程序,其中我调用异步“q”函数,只是抛出异常.这个程序非常一致地泄漏内存;但如果取消注释.done()调用,泄漏就会消失.
当promise未终止时(即没有done()调用),为什么会发生泄漏?我试图遵循documentation,但无法理解done()方法的解释.在此先感谢您的帮助!
这是我的代码:
(function() { var MAX_ITER_COUNT,Q,iterCount,maxMem,noop,qDoit,test; Q = require("q"); iterCount = 0; MAX_ITER_COUNT = 10 * 1000; maxMem = 0; noop = function() {}; qDoit = function() { var currentMem; currentMem = Math.round(process.memoryUsage().heapUsed / 1024 / 1024); if (currentMem > maxMem) { maxMem = currentMem; } console.log("" + iterCount + " - memory is: " + currentMem + "/" + maxMem + " MB"); return Q(10).then(function() { throw new Error("X"); }); }; test = function() { if (iterCount++ > MAX_ITER_COUNT) { console.log("DONE"); return; } // ---- If I uncomment the done() call below the leak goes away ---- return qDoit()["finally"](function() { return setImmediate(test); }) //.done(noop,noop); }; Q.onerror = function() {}; test(); }).call(this);
解决方法
回答我自己的问题,希望它会帮助某人.
在对q库代码进行挖掘时,默认情况下看起来所有未处理的异常都放在一个名为unhandledRejections的数组中.不知道为什么它是这样实现的,但可能是为了帮助开发人员追踪未处理的异常.可以通过调用Q.stopUnhandledRejectionTracking()来更改此行为.当我这样做时,即使没有.done()调用,内存泄漏也会消失.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。