- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
Java 应该不会有内存泄漏,但它仍然是可能的。当我的程序有内存泄漏时,我可以修复它(我希望)。但是当一些第三方包有它时我该怎么办?除了不使用这个包外几乎什么都没有。
还有其他解决方案吗?我喜欢沙箱的想法。你可以在某个区域内做任何你想做的事,而且你的“ body ”没有能力在你的盒子外打扰其他人。有没有办法在 Java 中为内存使用创建这样的沙箱?想象一下=为内存使用创建沙箱,允许一些包做任何它做的事情,获取结果并删除这个沙箱,不管这里留下什么垃圾!没有 GC 的并发症,没有清理或处置内存。只需删除并忘记它。
有什么办法吗?
最佳答案
最好的方法是启动另一个 JVM,通过套接字与其通信(例如),并在完成后终止 JVM。
讨论我们是否可以在同一个 JVM 中将其沙箱化会很有趣。
在您使用完第 3 方库后,您不再引用该库中的任何对象,仍然挥之不去的垃圾可能是什么?
它们的类 - 即使您没有引用它们中的任何一个,如果它们由与您的代码相同的类加载器加载,这些类将持续存在。他们的静态字段可以引用更多的延迟数据,等等
ThreadLocal - 它可以设置一些线程局部变量,而不是清除它们
线程 - 它可能会产生一些持续存在的线程
在全局某个地方 - 例如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/
我是一名优秀的程序员,十分优秀!