当Float对象在第二行被创建时,什么时候能被垃圾回收站回收?
1.public Object m(){
2. Object o = new Float(3.14F); //o----------> new Float(3.14f)
3. Object[] oa = new Object[1];
4. oa[0] = o; // o----------> new Float(3.14f) <--------------- oa[0]
5. o = null; // o----------> null , oa[0]---------------> new Float(3.14f)
6. oa[0] = null; // o----------> null , oa[0]---------------> null , new Float(3.14f)
到这一步,这个对象不再有任何引用了,也就是成了垃圾对象了
7. return 0;
}
java中是否存在内存泄漏?
Java中的内存泄露,广义并通俗的说,就是:不再会被使用的对象的内存不能被回收,
就是内存泄露。如果长生命周期的对象持有短生命周期的引用,就很可能会出现内存泄露。
什么情况下才是内存泄漏?
1.长生命周期的对象持有短生命周期对象的引用就很可能发生内存泄露。例如,缓存系统,我们加载了一个对象放在缓存中(例如放在一个全局map对象中),然后一直不再使用它,这个对象一直被缓存引用,但却不再被使用。
2.集合类,而如果集合类是全局性的变量(比如类中的静态属性,全局性的map等即有静态引用或final一直指向它),那么没有相应的删除机制,很可能导致集合所占用的内存只增不减,因此提供这样的删除机制或者定期清除策略非常必要。
3.单例模式。不正确使用单例模式是引起内存泄露的一个常见问题,单例对象在被初始化后将在JVM的整个生命周期中存在(以静态变量的方式),如果单例对象持有外部对象的引用,那么这个外部对象将不能被jvm正常回收,导致内存泄露