栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

Java 内存区域

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java 内存区域

这里写目录标题
    • 1:概述
    • 2:运行时数据区域
          • 1.1 程序计数器
          • 1.2 Java虚拟机栈
          • 1.3 堆
          • 1.4 方法区
    • 3:HotSpot虚拟机
    • 4:内存溢出

1:概述

Java 与C++ 之间有一堵由内存动态和垃圾收集技术所围成的墙,墙外的人想进行,墙里的人想出来。
C,C++ 对于开发人员来说,在内存区域他们拥有最高的权利,对于每一个对象的“所有权”,又肩负着每一个对象的生命从开始到结束。
对于Java 在虚拟机自动内存管理机制的帮助下,不需要考虑对象的内存管理,但是出现内存泄漏之类的问题,如果不了解虚拟机,修复问题会是一件很艰难的工作

2:运行时数据区域

Java 内存区域和内存模型是不一样的东西。内存模型(JMM),是定义了线程和主内存之间的抽象关系,即JMM定义了JVM在计算机内存(RAM) 中的工作方式

1.1 程序计数器

程序计数器(Program Counter Register):较小的内存空间,当前线程执行的字节码的行号指示器(例如:分支,循环,跳转,异常处理);线程私有;执行Java方法,计数器记录的是正在执行的虚拟机字节码指令地址;执行本地方法,计数器则为空;唯一一个在《Java虚拟机规范》中没有规定OOM的情况的区域

1.2 Java虚拟机栈

Java虚拟机栈(Java Virtual Machine Stack) :线程私有;方法被执行时候,Java虚拟机都会同步创建一个栈帧(Stack frame)用于存储局部变量,操作动态数栈,动态连接,方法出口等
局部变量表存储了编译期可知的各种java虚拟机基本数据类型(boolean,byte,char,short,int,float,long,double),对象引用(reference)。
可能发生的异常:StackOverflowError 和 OutOfMemoryError 异常。

1.3 堆

堆:虚拟机管理的最大内存区域,被所有线程共享;次区域的唯一目的就是存放对象实例,Java世界里“几乎”,所有的对象都在这里分配。Java堆是垃圾收集器管理的内存区域,被称作“GC堆”;

一般我们的了解的Java虚拟机的堆内存分为新生代(Eden:S0:S1 = 8:1:1),老年代等区域。在十年之前(G1收集器的出现分界),作为绝对主流的HotSpot虚机,它内部的垃圾收集器全部基于“经典分代”来设计。到了今天垃圾收集器已经变化很大,HotSpot虚拟机里面也出现了不采用分代设计的新垃圾收集器。可通过 -Xmx 和 -Xms 设定虚拟机堆内存大小

设置JVM内存的参数有四个:
-Xmx : Java Heap最大值,默认值为物理内存的1/4,最佳设值应该视物理内存大小及计算机内其他内存开销而定;
-Xms : Java Heap初始值,Server端JVM最好将-Xms和-Xmx设为相同值,开发测试机JVM可以保留默认值;
-Xmn : Java Heap Young区大小,不熟悉最好保留默认值;
-Xss : 每个线程的Stack大小,不熟悉最好保留默认值;

1.4 方法区

方法区:在分代里面又被称为永久代

3:HotSpot虚拟机 4:内存溢出
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/642373.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号