如何编写Java代码,故意制造一个能引发严重内存泄露的长尾词程序?
- 内容介绍
- 文章标签
- 相关推荐
本文共计503个文字,预计阅读时间需要3分钟。
如果你想生成错误的键值对,可以这样实现:
javaclass BadKey { // no hashCode or equals public final String key;
public BadKey(String key) { this.key=key; }}
如果你想要生成错误的键值对可以像下面这样做classBadKey{nohashCodeorequals();publicfinalStringkey如果你想要生成错误的键值对可以像下面这样做
class BadKey {
// no hashCode or equals();
public final String key;
public BadKey(String key) { this.key key; }
}
Map map System.getProperties();
map.put(new BadKey("key"), "value"); // Memory leak even if your threads die.
A4除了被遗忘的监听器静态引用hashmap中key错误/被修改或者线程阻塞不能结束生命周期等典型内存泄露场景下面介绍一些不太明显的Java发生内存泄露的情况主要是线程相关的。
Runtime.addShutdownHook后没有移除即使使用了removeShutdownHook由于ThreadGroup类对于未启动线程的bug它可能不被回收导致ThreadGroup发生内存泄露。
本文共计503个文字,预计阅读时间需要3分钟。
如果你想生成错误的键值对,可以这样实现:
javaclass BadKey { // no hashCode or equals public final String key;
public BadKey(String key) { this.key=key; }}
如果你想要生成错误的键值对可以像下面这样做classBadKey{nohashCodeorequals();publicfinalStringkey如果你想要生成错误的键值对可以像下面这样做
class BadKey {
// no hashCode or equals();
public final String key;
public BadKey(String key) { this.key key; }
}
Map map System.getProperties();
map.put(new BadKey("key"), "value"); // Memory leak even if your threads die.
A4除了被遗忘的监听器静态引用hashmap中key错误/被修改或者线程阻塞不能结束生命周期等典型内存泄露场景下面介绍一些不太明显的Java发生内存泄露的情况主要是线程相关的。
Runtime.addShutdownHook后没有移除即使使用了removeShutdownHook由于ThreadGroup类对于未启动线程的bug它可能不被回收导致ThreadGroup发生内存泄露。

