zoukankan      html  css  js  c++  java
  • java虚拟机内存模型

    Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域。

    这些区域都有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有些区域则是依赖用户线程的启动和结束而建立和销毁。

    Java虚拟机所管理的内存将会包括以下几个运行时数据区域:Method Area(方法区),VM Stack(虚拟机栈),Native Method Stack(本地方法栈),Heap(堆),Program Counter Register(程序计数器)。

    Method Area

    • 生命周期:Java虚拟机进程的启动与关闭
    • 存储内容:类信息,常量,静态变量,即时编译器编译的字节码
    • 存储内容是线程共享的

    VM Stack

    • 生命周期:用户线程的启动与关闭
    • 存储内容:局部变量表,操作栈,动态链接,方法出口
    • 存储内容是线程独享的

    Native Method Stack与VM Stack相似,只是只与Native方法相关

    Heap

    • 生命周期:Java虚拟机进程的启动与关闭
    • 存储内容:对象实例,数组
    • 存储内容是线程共享的

    Program Counter Register

    • 生命周期:用户线程的启动与关闭
    • 存储内容:字节码执行记录
    • 存储内容是线程独享的
  • 相关阅读:
    http协议
    三次握手四次挥手的原理
    mmap
    I/O多路复用之poll
    I/O多路转接之select
    自旋锁、文件锁、大内核锁
    网络基础(一)
    线程同步之(信号量)
    进程与线程的简单理解
    内存溢出——程序员必备网站
  • 原文地址:https://www.cnblogs.com/andyyang1013/p/12877691.html
Copyright © 2011-2022 走看看