// 堆:是大家共有的空间,分全局堆和局部堆。全局堆就是所有没有分配的空间,局部堆就是用户分配的空间。堆在操作系统对进程初始化的时候分配,运行过程中也可以向系统要额外的堆,但是记得用完了要还给操作系统,要不然就是内存泄漏。
// 栈:是个线程独有的,保存其运行状态和局部自动变量的。栈在线程开始的时候初始化,每个线程的栈互相独立,因此,栈是 thread safe的。操作系统在切换线程的时候会自动的切换栈,就是切换 SS/ESP寄存器。栈空间不需要在高级语言里面显式的分配和释放。
堆栈方法区:
1.jvm一个堆区多个栈区,一个线程一个栈。
2.堆heap: 运行时动态分配,存取比较慢。堆数据区是用来存放对象和数组(特殊的对象)。
堆所占内存的大小通过-Xmx指令和-Xms指令来调节
3.栈stack:Java栈的区域很小,只有1M,特点是存取速度很快,所以在stack中存放的都是快速执行的任务,基本数据类型的数据,和对象的引用(reference)。
栈所占内存的大小通过-Xss设置
4.方法区:它与堆一样,是被线程共享的区域。在方法区中,存储了每个类的信息(包括类的名称、方法信息、字段信息)、静态变量、常量以及编译器编译后的代码等。
方法区的大小由-XX:PermSize和-XX:MaxPermSize来调节
5.PC寄存器:存放线程执行指令的地址。
java栈: 存放Java方法的各种变量和对象的引用。Java方法执行的内存模型。每个线程都有一个Java栈。只有1M。
当线程执行一个方法时,就会随之创建一个对应的栈帧,并将建立的栈帧压栈。
当方法执行完毕之后,便会将栈帧出栈。因此可知,线程当前执行的方法所对应的栈帧必定位于Java栈的顶部。
堆: 存放对象本身和数组。堆是被所有线程共享的。jvm中只有一个堆。
程序计数器:存放命令的执行顺序。每个线程有独立的程序寄存器。
由于在JVM中,多线程是通过线程轮流切换来获得CPU执行时间的,因此,在任一具体时刻,
一个CPU的内核只会执行一条线程中的指令,因此,为了能够使得每个线程都在线程切换后能够恢复在切换之前的程序执行位置
每个线程都需要有自己独立的程序计数器,并且不能互相***扰,否则就会影响到程序的正常执行次序。
方法区: 存放类的基本信息,静态变量和编译器编译后的代码等。公用。
公用:堆,方法区
每个线程一个:栈,程序计数器。
全部评论
(1) 回帖