java 的垃圾回收


java 的垃圾回收

 没有垃圾回收可能会导致的问题:
1、内存泄漏
2、数组溢出
3、空指针引用;
java的垃圾回收算法:主要完成垃圾回收,碎片整理
1、标记清除   需要扫描两次
2、复制算法:将虚拟内存分为两部分,永远只用一半的内存,如果一半的内存满了,就将活着的对象放倒另一半,并且压缩存放,这样就可以把刚才满的一半内存全部回收。
缺点:内存的利用率太低,只能用一半内存。
3、提出新的优化,标记压缩(标记整理)
堆内存按代回收:
出现永久代、新生代、老年代:类加载载永久代,新new的类在新生代中,如果在新生代满了没有对象还存活 则移入老年代,这样新生代全部回收,这样新生代回收多次,老年代可能才回收一次。

判断对象是否存活一般有两种方式:

引用计数:每个对象有一个引用计数属性,新增一个引用时计数加1,引用释放时计数减1,计数为0时可以回收。此方法简单,无法解决对象相互循环引用的问题。

可达性分析(Reachability Analysis):从GC Roots开始向下搜索,搜索所走过的路径称为引用链。当一个对象到GC Roots没有任何引用链相连时,则证明此对象是不可用的。不可达对象。

GC Root 包括:

  • 方法区中类静态属性引用的对象;
  • 方法区中常量引用的对象;
  • Java方法的局部变量或参数
  • 活动着的线程,可以作为root



参考连接
http://www.cnblogs.com/ityouknow/p/5614961.html
http://www.07net01.com/2016/05/1495182.html



java  的资源泄露包括类型:
1、打开数据库连接没有关闭  ,网络链接没有关闭
2、 静态集合类引起内存泄露: 
像HashMap、Vector等的使用最容易出现内存泄露,这些静态变量的生命周期和应用程序一致,他们所引用的所有的对象Object也不能被释放,因为他们也将一直被Vector等引用着。 
例: 
Static Vector v = new Vector(10); 
for (int i = 1; i<100; i++) 

Object o = new Object(); 
v.add(o); 
o = null; 
}// 
在这个例子中,循环申请Object 对象,并将所申请的对象放入一个Vector 中,如果仅仅释放引用本身(o=null),那么Vector 仍然引用该对象,所以这个对象对GC 来说是不可回收的。因此,如果对象加入到Vector 后,还必须从Vector 中删除,最简单的方法就是将Vector对象设置为null。


参考链接:http://blog.csdn.net/seelye/article/details/8269705
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值