电脑内存广义上分为三块:
1、RAM(随机)
2、ROM(只读)
3、cache(高速缓存)。
而RAM又被称为主存。
Java内存的可分为Heap(堆内存)和Stack(栈内存)。//从程序员关注的角度粗糙划分,实际远不止
Stack的最顶端一般会留存在 CPU registers 和 cache 中。遇到频繁但是层次不多的函数调用,可以利用高速 cache。大块的内存会破坏这种优化。(来自知乎)
相同点:
1、Heap、Stack都会被GC自动回收
Stack:
1、速度比Heap快
2、在创建对象时会先去查询相同值,如果有直接引用,如果没有则创建一个(共享机制)
3、先进后出
4、数据大小与生存期必须是确定的
Heap:
1、空间比Stack大
2、new 后存放在Heap中可由程序员手动回收(把对象置为null,GC检测没引用会自动销毁)
3、先进先出
1、基本类型(八大基本类型)
int=1;//局部变量
这时会分配到Stack中
2、引用类型(也称包装类型)
Integer=1;(JDK5之后可以直接赋值,在底层会自动帮你new Integer(1))
这时会分配到Heap中
3、String(特殊的引用类型)
String="1";
存在Stack
String=new String("1");
System.out.println(a == "aa");//true
String b = new String("bb");
System.out.println(b == "bb");//false
String c = "c";
String d = "d";
String e = c+d;
System.out.println(e == "cd");//false
String f = null;
String g = new String("gg");
f = g;
1、RAM(随机)
2、ROM(只读)
3、cache(高速缓存)。
而RAM又被称为主存。
Java内存的可分为Heap(堆内存)和Stack(栈内存)。//从程序员关注的角度粗糙划分,实际远不止
Stack的最顶端一般会留存在 CPU registers 和 cache 中。遇到频繁但是层次不多的函数调用,可以利用高速 cache。大块的内存会破坏这种优化。(来自知乎)
相同点:
1、Heap、Stack都会被GC自动回收
2、存储在RAM
不同点:Stack:
1、速度比Heap快
2、在创建对象时会先去查询相同值,如果有直接引用,如果没有则创建一个(共享机制)
3、先进后出
4、数据大小与生存期必须是确定的
Heap:
1、空间比Stack大
2、new 后存放在Heap中可由程序员手动回收(把对象置为null,GC检测没引用会自动销毁)
3、先进先出
4、动态分配内存大小(这也是为什么会慢的原因)
5、堆中不存放基本类型和对象引用,只存放对象本身
Java数据类型分为两种:
拿int举例1、基本类型(八大基本类型)
int=1;//局部变量
这时会分配到Stack中
2、引用类型(也称包装类型)
Integer=1;(JDK5之后可以直接赋值,在底层会自动帮你new Integer(1))
这时会分配到Heap中
3、String(特殊的引用类型)
String="1";
存在Stack
String=new String("1");
存在Heap
例:
String a = "aa";System.out.println(a == "aa");//true
String b = new String("bb");
System.out.println(b == "bb");//false
String c = "c";
String d = "d";
String e = c+d;
System.out.println(e == "cd");//false
String f = null;
String g = new String("gg");
f = g;
System.out.println(f == g);//true
4、存放在class中
class A{
int a = 1;
}
这时class A是放在Heap,所以int a也放在Heap
PS:供自己复习使用