java中的GC、堆、栈

**GC:**就是垃圾回收机制;GC可以找到内存中的垃圾并释放和回收空间
**GC里的垃圾:**是指程序中不再需要使用的对象,以及不能再访问到的对象
**GC算法:**是一种机制,垃圾回收器完成具体的工作,工作的内容就是查找垃圾释放空间并回收,算法就是工作时查找和回收所遵循的规则

java堆:
是运行时数据区,类的对象从堆中分配空间,这些对象是通过new等指令建立,通过垃圾回收器来销毁
优势是可以动态的分配内存控制,需要多少内存控制不需要提前告诉编辑器,因为是在运行时动态分配的
缺点就是存取速度慢,因为动态分配
是java虚拟金管理内存最大的一块,是被所有线程共享的,主要作用是存放对象实例

java栈:
主要存放一些基本数据类型的变量(byte,short,int,long,float等)和对象的引用
优势是存取速度比对快,数据可以共享;
缺点是存放在栈中的数据需要的内存需要在编译时就确认,相比堆而言缺乏灵活性

public class Test1 {
    //方式一:使用new创建对象,故它是存放在堆中;   每调用一次就创建一个新的对象
    public static void main(String[] args) {
        String str1 = new String("abc");
        String str2 = new String("abc");
        System.out.println(str1 == str2);  //返回结果为:false
    }
}
public class Test1 {
    //方式二:先在栈中创建对象的引用str2,然后查找栈中有没有存放abc,如果没有,就把”abc“存放进栈,并将str2指向”abc“,如果已有就直接指向
    //此方式创建多个“abc”字符串,在内存中其实只存在一个对象而已,这种写法有利于节省内存空间;因此还可以提供程序的运行速度,因为JVM会自动根据栈中数据的实际情况来判断是否创建新对象
    public static void main(String[] args) {
        String str1 = "abc";
        String str2 = "abc" ;
        System.out.println(str1 == str2);  //返回结果为:true
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

As。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值