JAVA的JVM的内存可分为2个区:堆(heap)、栈(stack)。
堆和栈在数据结构中是两种不同的数据结构。 两者都是数据项按序排列的数据结构。
栈 | 堆:存储的全部是对象,每个对象都包含一个与之对应的class的信息 | |
优劣势:(系统自动分配,速度快,是一个连续的内存空间) | 堆的优劣势:(是一个不连续的内存空间,分配灵活,速度慢) | 方法区(method) |
每一个线程包含一个stack区,只保存基本数据类型的对象和自定义对象的引用(不是对象),对象都存放在共享heap中;每个栈中的数据(基本数据类型和对象引用)都是私有的,其他栈不能访问; 栈分为3部分:基本类型变量区、执行环境上下文、操作指令区(存放操作指令) 栈的优势劣势:存取速度比堆要快,仅次于直接位于CPU的寄存器,但必须确定的是存在stack中的数据大小与生存期必须是确定的,缺乏灵活性。单个stack的数据可以共享。 stack:是一个先进后出的数据结构,通常保存方法中的参数,局部变量。在java中,所有基本类型和引用类型都在stack中储存,栈中数据的生存空间一般在当前scopes内 | 堆的优势是可以动态的分配内存大小,生存期也不必事先告诉编译器,java的垃圾收集器会自动收取这些不在使用的数据,但缺点是,由于要在运行时动态分配内存,存取速度慢。 | 1、又叫静态区,跟堆一样,被所有的线程共享。方法区包含所有的class和static变量; 2、方法区中包含的都是在程序中永远的唯一的元素 |
类的相关信息: 1.代码 2.静态变量(注意,static修饰静态变量) 3.静态方法 4.字符串常量
|