美文网首页
JVM内存模型

JVM内存模型

作者: Yeahyeah313 | 来源:发表于2018-06-30 20:39 被阅读0次

    1.JVM的内存在物理内存中并不一定是连续的,在逻辑上是连续的
    2.JVM内存可以分为堆和非堆内存,线程私有和共享。

    JVM内存模型

    JVM内存模型包括

    线程私有
    1.程序计数器
    最小的一块内存模型,记录下一条需要执行的字节码指令
    2.虚拟机栈
    Java方法执行的内存区域,每个方法执行时都会产生一个栈帧,存储局部变量表,操作栈(临时数据存储区域),方法出口,实例方法第一个引用是this
    3.本地方法栈
    与虚拟机栈类似,是为Native方法服务

    共享
    1.堆
    GC管理的主要区域,绝大部分创建的对象实例和数据都在堆上,分为新生代,老生代
    新生代:Eden Space + S0(From Space) + S1(To Space)
    老生代: Tenured Generation,存储垃圾回收多次后仍存活的对象
    2.方法区
    也称”永久代” 、“非堆”, 它用于存储虚拟机加载的类信息、常量、静态变量、JIT即时编译后的代码,是各个线程共享的内存区域
    运行时常量池:是方法区的一部分,Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池,用于存放编译器生成的各种符号引用,这部分内容将在类加载后放到方法区的运行时常量池中。

    堆和栈的区别:
    1.存储对象不同,栈存储的是局部变量和方法调用
    堆存储的是对象和数组
    2.栈是线程私有,堆是线程共享
    3.栈的空间远小于堆
    4.栈空间不足:java.lang.StackOverFlowError。
    堆空间不足:java.lang.OutOfMemoryError。

    内存溢出(Out of Memory)和内存泄漏(Memory Leak)的区别
    内存溢出是指在申请内存空间时没有足够的空间
    内存泄露则是在存在垃圾回收器无法自动回收的对象,导致空间不足

    直接内存
    不属于JVM,分配本机内存

    相关文章

      网友评论

          本文标题:JVM内存模型

          本文链接:https://www.haomeiwen.com/subject/wvwtuftx.html