**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
}
}