最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

垃圾回收如何处理 Node.js HTTP(S) 请求?

网站源码admin30浏览0评论

垃圾回收如何处理 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 请求,这可能会导致泄漏。或者,即使请求和响应对象被释放,事件侦听器也可能继续运行?但是在这种情况下,事件监听器本身不会仍然存在,再次导致泄漏吗?

回答如下:
发布评论

评论列表(0)

  1. 暂无评论