如何处理 Node.js HTTP(S) 请求?"/>
垃圾回收如何处理 Node.js HTTP(S) 请求?
我在重复调用一个执行HTTPS请求的函数,类似如下:
const https = require('https');
foo()
{
const request = https.request('', { method: 'GET' }, (response) =>
{
let output = '';
response.on('data', (data) =>
{
output += data;
});
response.on('end', () =>
{
console.log(output);
});
});
request.on('error', (error) =>
{
console.log(error);
});
request.end();
}
这段代码会导致内存泄漏吗?我的理解是请求和响应对象一旦“无法访问”就可以进行垃圾回收,但我不确定这到底需要什么。我会假设
const
对请求对象的引用没有障碍,因为一旦 foo
终止,它可能会超出范围,但是事件侦听器呢,它们似乎存活了 foo
?看起来他们应该保留请求和响应对象以允许即使在 foo
终止后也能处理 HTTPS 请求,这可能会导致泄漏。或者,即使请求和响应对象被释放,事件侦听器也可能继续运行?但是在这种情况下,事件监听器本身不会仍然存在,再次导致泄漏吗?
回答如下:
更多推荐
垃圾回收如何处理 Node.js HTTP(S) 请求?
发布评论