说一下堆和栈的区别?
参考答案:
1、功能方面:堆是用来存放对象的,栈是用来执行程序的。
2、共享性:堆是线程共享的,栈是线程私有的。
3、空间大小:堆大小远远大于栈。
如何判断对象是否需要回收?
参考答案:
有两种算法:引用计数法和根可达算法。
详细说明:
1、引用计数法:给每个对象添加一个引用计数器,每当有一个对象引用它,计数器+1,引用失效时计数器-1。当计数器为0时,就判定该对象可回收。
该方法存在一个问题,那就是如果两个对象相互引用,那么计数器永远不会为0。
2、根可达算法:每个对象的创建都是以GC Root作为对象的起点,每发生一次对象引用,就会往引用链中增加一个对象。当发生GC时,这些没有根对象的引用就会被回收。