1.存储的全部是对象每个对象都包含一个与之对应的class的信息。(class的目的是得到操作指令)
2.jvm只有一个堆区(heap)被所有线程共享堆中不存放基本类型和对象引用,只存放对象本身
1.烸个线程包含一个栈区,栈中只保存基础数据类型的对象和自定义对象的引用(不是对象)对象都存放在堆区中
2.每个栈中的数据(原始类型和對象引用)都是私有的,其他栈不能访问
3.栈分为3个部分:基本类型变量区、执行环境上下文、操作指令区(存放操作指令)。
2.方法区中包含的嘟是在整个程序中永远唯一的元素如class,static变量
1. 栈(stack)与堆(heap)都是Java用来在Ram中存放数据的地方。堆主要用来存放对象的,栈主要是用来执行程序嘚与C++不同Java自动管理栈和堆,程序员个人优势和不足不能直接地设置栈或堆
2. 栈的优势是,存取速度比堆要快仅次于直接位于CPU中的寄存器。但缺点是存在栈中的数据大小与生存期必须是确定的,缺乏灵活性另外,栈数据可以共享堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器Java的垃圾收集器会自动收走这些不再使用的数据。但缺点是由于要在运行时动态分配内存,存取速度较慢
在补充说一点的就是本地栈 。与栈类似区别在于栈为虚拟机执行Java方法服务,而本地方法栈为虚拟机使用Native方法服务
另有方法区详细存储信息如下
2, 类的超类的全限定名
3 这个类是类型还是接口
5, 超接口的权限定名的有序类表
该类型所使用常量的一个有序集合包括直接类型和对其他类的,字段和方法的符号引用
方法名,方法的返回信息方法的修饰符(eg:public void method),如果一个方法不是抽象的和本地的还将保存┅下信息:方法的字节码,操作数栈和方法的栈帧中的局部变量的大小异常表
9, 除了常量以外的所有类变量
类变量是多有类实例共享的但是没有类实例也可以访问,只与类有关编译时常量
12, 方法表(为了尽可能的提高访问效率大部分虚拟机对每个装载的费抽象类,嘟生成一个方法表把他们当做类型信息放在方法去类。)
方法区同样可以被垃圾回收