choway
2018-12-11 09:23:46

JavaJVM

Java 虚拟机(JVM)在执行 Java 程序时会把它管理的内存划分为多个不同的数据区域。这些区域各有用途,以及创建和销毁的时间。有些内存区域随着虚拟机进程的启动而存在,有些区域则依赖用户线程的启动和结束而建立和销毁。

程序计数器(Program Counter Register)

由于 JVM 的多线程是通过线程切换并分配处理器执行时间的方式来实现的,所以在任何一个时刻,一个处理器(多核CPU的一个内核)都只会执行一条线程,线程切换后为了确保每个线程能恢复到正确的执行位置,每个线程都需要有个独立的程序计数器。

  • 线程私有;
  • 唯一一个在 JVM 规范中没有规定任何 OutOfMemoryError 的区域;

JVM 栈(JVM Stacks)

Java 方法在执行时会创建一个栈帧(Stack Frame)用于存储局部变量表、操作数栈、动态链接、方法出口等信息;
每个方法从调用到执行结束,对应一个栈帧在 JVM 栈中的入栈到出栈过程;
如果线程请求的栈深度大于 JVM 所允许的深度,将抛出 StackOverflowError;
如果 JVM 栈可以动态扩展,如果扩展时无法申请到足够的内存,就会抛出 OutOfMemoryError;

  • 线程私有;
  • 在 JVM 规范会抛出 StackOverflowError、OutOfMemoryError;

栈溢出(StackOverflowError)

在 HotSpot 虚拟机中并不区分虚拟机栈和本地方法栈,栈容量使用 -Xss 参数设定;

JVM 堆(JVM Heap)

JVM 堆是被所有线程共享的内存区域,在虚拟机启动时创建;
JVM 规范:所有的对象实例以及数组都在堆上分配;
堆是垃圾回收器管理的主要区域,因此也被称为 GC 堆;
如果在堆中没有内存完成实例分配,并且堆也无法扩展,则抛出 OutOfMemoryError;

堆溢出(OutOfMemoryError,简称 OOM)

  • -Xms 设定堆最小值,即初始化堆大小;
  • -Xmx 设定堆最大值,当堆内存不够时,堆大小会自动扩展,直到达到堆最大值;
    -Xms 和 -Xmx 设置一样可避免堆自动扩展;

方法区(Method Area)

方法区用于存储已被 JVM 加载的类信息、常量、静态变量、即使编译器编译后的代码等数据,各个线程共享;
该区域的内存回收目标主要针对常量池的回收和类型卸载;

  • 线程共享;
  • 在 JVM 规范中,当方法区无法满足内存分配,则抛出 OutOfMemoryError;

运行时常量池(Runtime Constant Pool)

常量池是方法区的一部分,也会抛出 OutOfMemoryError;
Class 文件除了有类的版本、字段、方法、接口等描述信息外,还有常量池用户存放编译期的各种字面量和符合引用,这些内容在类加载后进入方法区的运行时常量池中存放。

方法区、常量池溢出

-XX:PermSize 和 -XX:MaxPermSize 设定方法区大小;

直接内存(Direct Memory)

直接内存不是 JVM 运行时数据的一部分,也不是 JVM 规范中定义的内存。
在 JDK 1.4 中新加入了 NIO(New Input/Output)类,引入了一种基于通道(Channel)与缓冲区(Buffer)的 IO 方式,它可以直接使用 Native 库直接分配堆外内存。

  • -XX:MaxDirectMemorySize 参数指定直接内存大小;
  • 如果不指定,默认与 -Xmx 值一样;

Choway Blog的更多相关文章

  1. 日向blog开发记录

    一点历史关于,Sonne Blog 2016.03.25springmvc + hibernate框架搭建.2016.04.21日向blog首页.2016.04.24分页实现.2016.04.30登录 ...

  2. blog (后续更新)

    设计Model(设计数据库) from django.db import models # Create your models here. class BlogsPost(models.Model) ...

  3. tensorflow 一些好的blog链接和tensorflow gpu版本安装

    pading :SAME,VALID 区别  http://blog.csdn.net/mao_xiao_feng/article/details/53444333 tensorflow实现的各种算法 ...

  4. http://blog.csdn.net/java2000_wl/article/details/8627874

    http://blog.csdn.net/java2000_wl/article/details/8627874

  5. [Android Pro] http://blog.csdn.net/wuyinlei/article/category/5773375

    http://blog.csdn.net/wuyinlei/article/category/5773375

  6. android 蓝牙 http://blog.csdn.net/u012843100/article/details/52384219

    http://blog.csdn.net/u012843100/article/details/52384219

  7. 【三】用Markdown写blog的常用操作

    本系列有五篇:分别是 [一]Ubuntu14.04+Jekyll+Github Pages搭建静态博客:主要是安装方面 [二]jekyll 的使用 :主要是jekyll的配置 [三]Markdown+ ...

  8. django开发个人简易Blog—nginx+uwsgin+django1.6+mysql 部署到CentOS6.5

    前面说完了此项目的创建及数据模型设计的过程.如果未看过,可以到这里查看,并且项目源码已经放大到github上,可以去这里下载. 代码也已经部署到sina sea上,地址为http://fengzhen ...

  9. 使用Hexo搭建专属Blog

    喜欢折腾的自己最开始在博客园有仿写几篇Blog,虽也可以自己改变风格,可是到底不是独立的一块儿地方,要知道独立的才是自己的;有属于自己独立的域名和Blog,真真是一件很爽的存在.在各种大牛的分享下在G ...

随机推荐

  1. mui + H5 调取摄像头和相册 实现图片上传

    最近要用MUI做项目,在研究图片上传时 ,遇到了大坑 ,网上搜集各种资料,最终写了一个demo,直接看代码.参考(http://www.cnblogs.com/richerdyoung/p/66123 ...

  2. tensroflow中如何计算特征图的输出及padding大小

    根据tensorflow中的conv2d函数,我们先定义几个基本符号 1.输入矩阵 W×W,这里只考虑输入宽高相等的情况,如果不相等,推导方法一样,不多解释. 2.filter矩阵 F×F,卷积核 3 ...

  3. 上传本地项目到GIT码云

    1.下载GIT 下载地址:https://git-scm.com/downloads 我这里下载的64位 2.安装GIT 双击下载的Git-2.18.0-64-bit.exe文件,选择自己的安装目录, ...

  4. 使用meshgrid生成热图和单位向量场

    需求: 生成 中heatmap unit vector field 目前的数据: 图像的shape, 关键点的x,y , heatmap的半径R 思路: 如果使用for循环来判断距离,会很慢,如果预先 ...

  5. docker 一些简略环境搭建及部分链接

    1.center 7  搭建 docker https://www.cnblogs.com/yufeng218/p/8370670.html 2.docker 命令 https://www.cnblo ...

  6. HDU-4004 The Frog's Games (分治)

    http://acm.hdu.edu.cn/showproblem.php?pid=4004 Problem Description The annual Games in frogs' kingdo ...

  7. Sex linkage

    I.8 Sex linkage 单倍体:性别决定基因(S\s)和与性别决定基因连锁的等位基因(A\a)存在于同一套遗传物质上,其配子结合和减数分裂图示如下: 如果性别是由染色体区域决定的,自然选择会避 ...

  8. rsync配置文件

    vim /etc/rsyncd.conf motd file = /etc/rsyncd.motd #设置服务器信息提示文件,在该文件中编写提示信息 transfer logging = yes #开 ...

  9. nginx限制IP访问网站

    需求:网站只允许指定IP访问,其他访问一律拒绝server { listen 80; server_name a.com; index index.html index.htm index.php; ...

  10. Serverless 的开发者工具建设

    本文将介绍 Serverless 生态下的开发者工具,并简述这些工具是如何贯穿开发.调试.测试和部署的生命周期,提升开发者效率的. 由于 Serverless 平台具备弹性扩缩.免运维.按需付费等特点 ...