java 内存问题
来源:互联网 发布:淘宝化妆品店运营方案 编辑:程序博客网 时间:2024/05/07 20:03
今天在网上看到关于对JAVA内存的解释,觉得写的比较好便摘抄下来。
在Java中,内存泄漏就是存在一些被分配的对象,这些对象有下面两个特点,首先,这些对象是可达的,即在有向图中,存在通
路可以与其相连;其次,这些对象是无用的,即程序以后不会再使用这些对象。如果对象满足这两个条件,这些对象就可以判定为
Java中的内存泄漏,这些对象不会被GC所回收,然而它却占用内存。
在C++中,内存泄漏的范围更大一些。有些对象被分配了内存空间,然后却不可达,由于C++中没有GC,这些内存将永远收不回来
。在Java中,这些不可达的对象都由GC负责回收,因此程序员不需要考虑这部分的内存泄露。
通过分析,我们得知,对于C++,程序员需要自己管理边和顶点,而对于Java程序员只需要管理边就可以了(不需要管理顶点的释放
)。通过这种方式,Java提高了编程的效率。
因此,通过以上分析,我们知道在Java中也有内存泄漏,但范围比C++要小一些。因为Java从语言上保证,任何对象都是可达的,
所有的不可达对象都由GC管理。
对于程序员来说,GC基本是透明的,不可见的。虽然,我们只有几个函数可以访问GC,例如运行GC的函数System.gc(),但是根据
Java语言规范定义, 该函数不保证JVM的垃圾收集器一定会执行。因为,不同的JVM实现者可能使用不同的算法管理GC。通常,GC的
线程的优先级别较低。JVM调用GC的策略也有很多种,有的是内存使用到达一定程度时,GC才开始工作,也有定时执行的,有的是平
缓执行GC,有的是中断式执行GC。但通常来说,我们不需要关心这些。除非在一些特定的场合,GC的执行影响应用程序的性能,例如
对于基于Web的实时系统,如网络游戏等,用户不希望GC突然中断应用程序执行而进行垃圾回收,那么我们需要调整GC的参数,让GC
能够通过平缓的方式释放内存,例如将垃圾回收分解为一系列的小步骤执行,Sun提供的HotSpot JVM就支持这一特性。
下面给出了一个简单的内存泄露的例子。在这个例子中,我们循环申请Object对象,并将所申请的对象放入一个Vector中,如果我
们仅仅释放引用本身,那么Vector仍然引用该对象,所以这个对象对GC来说是不可回收的。因此,如果对象加入到Vector后,还必须
从Vector中删除,最简单的方法就是将Vector对象设置为null。
Vector v=new Vector(10);
for (int i=1;i<100; i++)
{
Object o=new Object();
v.add(o);
o=null;
}
//此时,所有的Object对象都没有被释放,因为变量v引用这些对象
- Java内存泄露问题
- Java内存泄露问题
- Java内存泄漏问题
- JAVA内存泄漏问题
- JAVA内存泄漏问题
- java的内存问题
- java 内存问题
- Java内存溢出问题
- JAVA内存泄漏问题
- java内存问题
- Java内存泄露问题
- Java内存泄露问题
- Java有关内存问题
- java内存溢出问题
- java内存处理问题
- Java内存泄露问题
- java内存模型问题
- Java内存泄露问题
- 软件文档编写向导
- assert.h
- linux下c编译系统(转)
- 关于HibernateDaoSupport getSession()不能释放资源的问题及解决方法
- java操作oracle数据库
- java 内存问题
- 正则表达式入门
- C 位操作
- Solaris Source Insight: PCI bus driver moduls - npe Part 3
- VB取得线程句柄
- C标准库头文件 assert.h
- 学习
- 很安静
- Linux信号量线程控制