gpt4 book ai didi

java - 内存沙盒

转载 作者:搜寻专家 更新时间:2023-10-31 20:33:38 26 4
gpt4 key购买 nike

Java 应该不会有内存泄漏,但它仍然是可能的。当我的程序有内存泄漏时,我可以修复它(我希望)。但是当一些第三方包有它时我该怎么办?除了不使用这个包外几乎什么都没有。

还有其他解决方案吗?我喜欢沙箱的想法。你可以在某个区域内做任何你想做的事,而且你的“ body ”没有能力在你的盒子外打扰其他人。有没有办法在 Java 中为内存使用创建这样的沙箱?想象一下=为内存使用创建沙箱,允许一些包做任何它做的事情,获取结果并删除这个沙箱,不管这里留下什么垃圾!没有 GC 的并发症,没有清理或处置内存。只需删除并忘记它。

有什么办法吗?

最佳答案

最好的方法是启动另一个 JVM,通过套接字与其通信(例如),并在完成后终止 JVM。

讨论我们是否可以在同一个 JVM 中将其沙箱化会很有趣。

在您使用完第 3 方库后,您不再引用该库中的任何对象,仍然挥之不去的垃圾可能是什么?

  1. 它们的类 - 即使您没有引用它们中的任何一个,如果它们由与您的代码相同的类加载器加载,这些类将持续存在。他们的静态字段可以引用更多的延迟数据,等等

  2. ThreadLocal - 它可以设置一些线程局部变量,而不是清除它们

  3. 线程 - 它可能会产生一些持续存在的线程

  4. 在全局某个地方 - 例如System.setProperty() - 它会留在那里。

所以一般来说,这可能很困难。

但是,我们可以使用一个单独的类加载器和一个单独的线程来执行第 3 方库,并且在大多数情况下,这种策略可能可以卸载第 3 方创建的所有垃圾。

是否有现成的工具可以做到这一点?我对此不太了解。我确实有一些实现可热重载服务器的经验,并且我有一些可用于此目的的实用程序类。例如

// wrap 3rd party code, expose it as some java.*.* interface
public class MyWrapper implements Callable<String>
{
@Override
public String call()
{
return ThirdParty.query(..);
}
}



HotReloader hot = new HotReloader();
Callable<String> func = (Callable<String>)hot.getAppInstance("pkg.MyWrapper");
String result = func.call();
// then dereference `hot` and `func`

参见 HotReloader

关于java - 内存沙盒,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30227510/

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