【问题标题】:std::queue memory consumption leads to memory leak - C++ ?std::queue 内存消耗导致内存泄漏 - C++?
【发布时间】:2014-03-24 17:28:08
【问题描述】:

即使在我从 qInt 队列中弹出所有元素后,以下代码也没有释放 3000 个元素消耗的内存。是什么原因 ?

std::queue<int> qInt; //Step01: Check the running memory

for (int i=0;i<3000;i++)
{       
    qInt.push(i);
}
//Step02: Check the running memory it should have been increased    

while(!qInt.empty())
{
    qInt.pop();
}
//Step03: Check the running memory expecting Step01 memory but it is still the same of Step02

【问题讨论】:

  • 你在用任务管理器检查内存消耗吗?
  • @Borgleader 当然是的
  • 您永远不会知道,您可能会将 3000 多个项目推入该队列。如果您希望最好的机会释放堆内存以准备即将发生的假设,请将其与本地空自动交换。
  • @WhozCraig 你提出了这样的方法。 std::queue 为空; std::swap(qInt, 空);如果我想清空整个队列,那很好。假设每当我使用 pop 时,如何减少为推送 3000 个元素分配的内存?
  • @Carthi 查看重新运行的答案和链接。它(他们)比我在评论中解释得更好。

标签: c++ visual-c++ memory stl queue


【解决方案1】:

默认情况下,std 容器一旦保留它就不会释放内存。 std::queue 通常在提供shrink_to_fit 的 std::dequeue 类型上实现。如果您不使用 c++ 11,请使用 swap idiom

【讨论】:

  • 你能向 std::queue 推荐一个sawp成语吗?
【解决方案2】:

如果您释放/释放/删除堆内存。这并不意味着内存消耗会立即下降。内存管理库有自己的空闲内存缓存,它们会在达到阈值后释放。

【讨论】:

    【解决方案3】:

    首先,3000 个整数使用的内存非常低,如果您使用任务管理器检查内存,则看不到内存使用的显着变化。此外,正如其他答案中所解释的,STL 容器不会立即解除分配。 有一个很好的forum 讨论 STL 对象和对象指针的内存分配和释放。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-03-01
      • 1970-01-01
      • 2021-12-25
      • 2010-12-23
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多