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:内存溢出
|