garbage-collection相关内容
jmap可以知道每一代的大小,但我希望实时监视我的Java进程。 使用jmx,MemoryMXBean.getHeapMemoryUsage().getUsed()可以获得总的堆大小。但我找不到任何方法来获取: 新(年轻)和终身(老)世代人数; 伊甸园的大小和新一代的每一个幸存者。 推荐答案 您可以使用ManagementFactory.getMemoryPoolMXBe
..
Go中有没有一种简单的方法来获取有关GC和堆大小的信息,以便将它们暴露在监视仪表板中。我看了一下运行时包,但似乎没有任何东西可以做到这一点。理想情况下,这应该不需要任何开销,如在分析模式下运行应用程序等,但应该为生产做好准备。 推荐答案 您可以使用GODEBUG=gctrace=1获得连续输出,runtime package中介绍了这一点。 否则,您需要从runtime.MemS
..
我正在玩WeakRef and FinalizationRegistry in V8,我无法验证以下代码在Node.js中是否可以正常工作。 我使用的是Node v15.3.0,运行方式如下: node --expose-gc transient.js: 我希望在控制台日志中看到一些finalizerCallback called!条目。 如果我在基于Chromium浏览器
..
背景 我正在尝试将灵丹妙药的参与者模型语言原语移植到JS中。我想出了一个解决方案(在JS中)来模拟receiveelxir关键字,使用";Receiver&Quot;函数和生成器。 这里是一个简化的实现和演示,向您展示这一想法。 接口: type ActorRef: { send(msg: any): void } type Receiver = (msg: any
..
我在堆栈溢出上遇到this answer此处: 当您分配的速度快于垃圾收集速度时,您将遇到OOM。如果您执行大量分配,CLR将插入睡眠(Xx)来限制分配,但在极端情况下这是不够的。 所以,我还没有读到任何关于CLR通过在内存不足时插入一条睡眠语句来减慢分配速度来限制分配的内容。有谁能证实这是真的还是假的?如果这是真的,那么有什么文件谈到了细节吗?我试过在谷歌上搜索,但找不到任何支持这一
..
为了在经常发生内存泄漏的地方检测潜在的内存泄漏,我使用了构建如下所示的测试。主要思想是拥有一个实例,而不再引用它,并让垃圾收集器收集它。我不想把重点放在这是不是一种好的技术上(在我的具体案例中,它做得很好),但我想集中讨论以下问题: 下面的代码在.NetFramework4.8上运行得很好,但在.Net 5上不能。为什么? [Test] public void ConceptualMe
..
我有一个PyQt QWidget(对象A;它只是一个暂停容器),其中包含多个子小部件(即,存在类似Qt的父子引用)。A的子部件是从另一个对象(对象B;不一定是Qt对象)引用的,该对象向A的子部件提供数据,并实际控制A的子部件的创建和结构。除了A的子级,对象B没有其他外部引用。对象A引用了对象B。因此,它是循环引用的纯粹教科书示例。 我想在某个时间点删除对象A和B的整个互连结构。我只需调用A.de
..
背景 您可以从以下代码中看到: var foo1 = new Promise (function (resolve, reject){}; var foo2 = new Promise (function (resolve, reject) { resolve('succes!'); }); var foo3 = new Promise (function (resolv
..
当我在C++/CLI DLL中实现类时: public ref class DummyClass { protected: !DummyClass() { // some dummy code: std::cout
..
从零使用开始: >>> import gc >>> import GPUtil >>> import torch >>> GPUtil.showUtilization() | ID | GPU | MEM | ------------------ | 0 | 0% | 0% | | 1 | 0% | 0% | | 2 | 0% | 0% | | 3 | 0% | 0%
..
澄清问题(tl;dr) 在阅读和分析下面涵盖的所有结果后,问题似乎归结为 GC 在服务器模式下没有为我们的应用程序收集 Gen 0 堆,一旦切换到工作站模式,问题就会消失. 原始问题和详细信息 我的问题有点相关:这个问题和这个问题. 我们最近在测试环境中的 .NET 应用程序中遇到了似乎是内存泄漏的问题,工作进程在负载下或在无负载时会逐渐攀升至 450MB 左右的使用量.
..
import javax.swing.*;公共类主{公共主要(){JFrame jf = new JFrame("Demo");jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);jf.setSize(100, 100);jf.setVisible(true);}公共静态无效主要(字符串 [] 参数){SwingUtilities.invokeLat
..
我在实现 IEnumerable 接口的对象池中有以下代码. public IEnumerable活动节点{得到{for (int i = 0; i
..
在我的 DAL 中,我编写如下查询: using(SQLConnection conn = "这里的连接字符串"){SQLCommand cmd = new ("sql 查询", conn);//执行它等等} 现在我突然想到我没有明确关闭 SQLCommand 对象.现在我知道“使用"块会处理 SQLConnection 对象,但这也会处理 SQLCommand 对象吗?如果不是那么我有一个严
..
我对 Julia 中的内存分配有点困惑.我从常见问题解答中知道已完成清除大变量使用的内存通过将其设置为较小的值(如 0),然后运行 gc(). 但是,我对以下内容有些困惑.我创建了一个随机 Float32 数组: @time A = rand(Float32, 10000, 10000); time 表示分配了大约 400MB 的 RAM,Julia 的 RAM 使用量增加了 400
..
在我的一个 Azure Web App Web API 应用程序中,我在 Get 方法中使用此代码创建临时文件 字符串路径 = Path.GetTempFileName();//在这个文件上写一些东西.然后阅读var fileStream = File.OpenRead(path);//然后将此流作为 HttpResponseMessage 响应返回 我的问题是,在这样的托管环境中(不是在
..
我需要为 Mono 使用的内存设置一个上限. 根据 blogs 可以使用参数 max-heap-size 来限制内存使用量.根据实验,根据代码,它确实做到了我想要的. 但是,此选项没有记录. 因此:在生产中依赖此选项是否安全(或者它是否有我看不到的缺点,例如:不能保证在未来的 Mono 版本中仍然可用)? 解决方案 有文档,获取文档的方法如下: export an inv
..
我正在尝试追踪单声道运行时中的一个错误,其中一个变量似乎被分配给一个有效对象,然后被重新分配给一个虚假对象,特别是 //在我分配的代码的早期,很好var o = 新对象();//有效分配//稍后在代码中调用 this,不好lock(o)//
..
现代垃圾收集器(如在 CLR、JVM 中)使用哪些技术来判断堆栈中引用了哪些堆对象? 具体来说,VM 如何从知道堆栈开始的位置返回到解释所有对堆对象的本地引用? 解决方案 在 Java 中(很可能在 CLR 中,虽然我不太了解它的内部结构),字节码是用对象与原始信息输入的.因此,字节码中有数据结构来描述每个堆栈帧中的哪些变量是对象,哪些是原语.当 GC 需要扫描根集时,它使用这些 S
..
使用反射擦洗 String 是否使使用 String 与使用 char[] 密码一样安全? 从安全方面来看,通常认为最好的做法是使用 char[] 来存储/传递密码,因为可以在代码中尽快将其内容归零,这可能是在垃圾收集清理它并重用内存(擦除所有跟踪)之前显着降低内存攻击的时间窗口. 但是,char[] 不如 String 方便,所以如果可以“擦洗"一个 String需要,从而使 Str
..