gpt4 book ai didi

java - ThreadPoolExecutor 中使用 BlockingQueue 的内存占用

转载 作者:行者123 更新时间:2023-11-30 08:43:26 25 4
gpt4 key购买 nike

我注意到每个 Runnable 对象的大小约为 600KB。我正在使用固定大小为 10000 的 BlockingQueue。从日志消息中,我看到所有 9864 个对象都已放入队列中。我没有看到任何内存使用量急剧增加。队列是否应该消耗 6GB (600KB x 9864) 内存?

最佳答案

  1. 首先,BlockingQueue 只有引用,所以BlockingQueue 会消耗非常小的内存。
  2. 其次,重要的不是队列中有多少对象,而是有多少唯一对象(队列可能有一百万个对一个对象的引用)。
  3. 最后,您如何计算每个 Runnable 对象的大小?还,每个 Runnable 对象都有很多指向另一个对象的链接,但是这个对象的一些可以在不同的 Runnable 对象之间共享,因此,如果第一个 Runnable 对象的大小约为 600KB,这并不意味着其他 Runnable 对象也将如此大。

关于java - ThreadPoolExecutor 中使用 BlockingQueue 的内存占用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34278352/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com