jvm参数

来源:互联网 发布:sql的distinct怎么删除 编辑:程序博客网 时间:2024/06/16 00:01

1.关于jvm

以jvm为主体的入口出口及内存执行结构

类加载器:于jvm而言为入口,是入口,通过文件系统或者网络中加载Class信息,加载的信息存放在一块称为方法区的内存空间


方法区:存放类信息,常量信息,常量池信息,包括字符串字面量和数字常量. 在jdk1.8前jdk的虚拟机有着不同版本,有的这块空间位于堆上单独一块称为永久区,后很多公司被Oracle

收购,在jdk1.8后,永久区被完全隔离出来称为方法区


堆:在java虚拟机启动的时候创建,,它是java程序最主要的内存工作区域,几乎所有的对象实例都存放到java堆中,堆空间是所有线程共享的


直接内存:java的NIO库允许java程序直接使用内存,从而提高性能,通常内存速度会由于java堆,读写频繁的场合可能考虑使用,同样的jdk1.8不仅仅对内存溢出做了优化,对空指针也做出了优化


栈:每个虚拟机线程都有一个私有的栈,一个线程的java栈在线程创建的时候被创建,java栈中保存着局部变量,方法参数和java的方法调用和返回值等


本地方法栈:  和java栈非常类似,最大不同为本地方法栈用于本地方法调用 java虚拟机允许java直接调用本地方法(通常使用C编写)


垃圾回收机制:gc是java的核心,也是必不可少的,java有一套自己进行垃圾清理的机制,开发人员无需手工清理


PC寄存器:PC寄存器是每个线程的私有空间,java虚拟机会为每个线程创建PC寄存器,在任意时候,java线程总是在执行一个方法.这个方法被称为当前方法,如果当前方法不是本地方法,PC寄存器就会执行当前正在被执行的指令,如果是本地方法,则PC寄存器值为undefined,寄存器存放如当前执行环境指针,程序计算器,操作栈指针,计算的变量的指针等信息


虚拟机最核心的组件就是执行引擎了,它负责执行虚拟机的字节码,将其编译为机器码执行

2.堆,栈,方法区的概念和联系


堆解决的数据存储的问题,即数据怎么放,放在哪儿

栈解决的是程序运行问题,即怎么执行,或者说是怎么处理数据

方法区是辅助堆栈的快永久区,解决堆栈信息的产生,是先决条件

当类被实例化,会在java堆中开辟一块内存空间,当我们去调用对象时,都是使用对象的引用这里的实例化出来的对象就是存放在java栈中的,及真实对象的引用

3.关于java堆如何自动化管理的



java堆和java应用程序关系最为密切的内存空间,几乎所有的对象都存放在其中,并且java堆是完全自动化管理的,通过垃圾回收机制,垃圾对象会自动清理,不需要显示的释放,

 根据垃圾回收机制的不同,java堆有可能有着不同的结构,最为常见的分为新生代老年代

说的就是,买新东西和丢垃圾的一个事,经常不舍得的丢的东西放一个地方,叫老年代,买来的东西放一个地方叫eden区,同样的这里放一些以前的东西,通过感觉东西多不多来决定要不要清理一下当垃圾丢掉,在新生代有两块大小相等并且可以互换角色的空间,也就是要去一堆东西中,捡出垃圾放一块,决定留下的放一块

新生代分为eden区,so区,s1区,s1和s0区也被称为from区和区,他们是两块大小相等并且可以互换角色的空间

绝大多数情况下,对象首先分配在eden区,在一次新生代回收后,如果对象还存活,会进入s0或者s1区,之后每一次gc,存活的对象年龄都会相应增加,当一定年龄则会进入老年代

4.垃圾的收集是通过什么样的机制来实现呢?   (垃圾收集的算法)

通过复制算法,s0区和s1区只有一个在运行,以 s0在运行为例,gc会找到正在运行的s0,即gc会清空s0这篇区域,仍在使用不想被清空的会复制到s1,然后s0被清空,

gc再次收集垃圾时候就会到s1,同样的s1会将不被回收的复制转移到s0,如此反复

5.java栈


java栈是一块私有的内存空间,一个栈,一般由三部分组成,局部变量表,操作数栈和帧数据区

局部变量表:用于报错函数的参数和局部变量

操作数栈:主要保存计算过程的中间结果

帧数据区: 除了局部变量和操作数栈以外,栈还需要一些数据来支持常量池的解析,这个帧数据区保存着访问常量池的指针,方便程序访问常量池  .当函数返回或出现异常时,虚拟机必须有一个异常处理表,方便发送异常的时候找到异常的代码,因此异常处理表也是帧数据区的一部分


6.java方法区

java方法区和堆一样,方法区是一块所有线程共享的内存区域,他保存系统的类信息,比如类的字段,方法,常量池.方法区的大小决定了系统可以保存多少个类.系统定义太多的类虚拟机同样会抛出内存溢出错误


7.虚拟机参数

package com.wpx.demo01;/** *  -XX:+PrintGC  使用这个参数,虚拟机启动后,只要遇到GC就会打印日志-XX:+UseSeriaiGC 配置串行回收器-XX:+PrintGCDetails可以查看详情信息-Xms:设置java程序启动时初始堆大小-Xmx:设置java程序能获得的最大堆大小-Xmx20m -Xms5m -XX:+PrintCommandLineFlags:可以将隐式或者显示传给虚拟机的参数输出 * @author wangpx */public class demo01 {public static void main(String[] args) {System.out.println("maxMemory: "+Runtime.getRuntime().maxMemory());System.out.println("freeMemory: "+Runtime.getRuntime().freeMemory());System.out.println("totalMemory"+Runtime.getRuntime().totalMemory());byte[] b1=new byte[1*1024*1024];System.out.println("分配了1M内存");System.out.println("maxMemory: "+Runtime.getRuntime().maxMemory());System.out.println("freeMemory: "+Runtime.getRuntime().freeMemory());System.out.println("totalMemory"+Runtime.getRuntime().totalMemory());byte[] b2=new byte[(int) (4.5*1024*1024)];System.out.println("分配了4.5M内存");System.out.println("maxMemory: "+Runtime.getRuntime().maxMemory());System.out.println("freeMemory: "+Runtime.getRuntime().freeMemory());System.out.println("totalMemory"+Runtime.getRuntime().totalMemory());}}

8.





实际上可以直接将初始的堆大小和最大的堆大小设置相等,这样的好处是可以减少程序运行是的垃圾回收次数,从而提高性能


8.新生代的配置

package com.wpx.demo01;/** * -Xmn:可以设置新生带的大小,新生代的gc比较频繁,一般设置为整个堆空间的1/3到1/4左右-XX:SurvlvoRatio:用来设置新生代中eden空间和form/to空间的比例-XX:SurvivorRatio=eden/from=eden/to不同的堆分布情况,对系统执行会产生一定的影响,在实际工作中,应该根据系统的特点做出合理的配置基本策略:尽可能将对象预留在新生带,减少老年代的GC次数除了可以设置新生带的绝对大小(-Xmn)还可以使用-XX:NewRatio新生代和老年代的比例    * @author wangpx */public class demo02 {public static void main(String[] args) {/** * -XX:+PrintGC -Xmx20m -Xms20m -XX:+UseSerialGC -XX:+PrintGCDetails -XX:SurvivorRatio=2-Xmn1m *    eden space 512K,   2% used [0x00000000fec00000, 0x00000000fec02a68, 0x00000000fec80000)  from space 256K,   0% used [0x00000000fecc0000, 0x00000000fecc0000, 0x00000000fed00000)  to   space 256K,   0% used [0x00000000fec80000, 0x00000000fec80000, 0x00000000fecc0000) *  初始化heap太小会是gc频繁,XX:SurvivorRatio=2=eden/from=eden/from */ /**  * -XX:+PrintGC -Xmx20m -Xms20m -XX:+UseSerialGC -XX:+PrintGCDetails -XX:SurvivorRatio=2-Xmn7m  *   eden space 3584K,  60% used [0x00000000fec00000, 0x00000000fee224b8, 0x00000000fef80000)  from space 1792K,  57% used [0x00000000ff140000, 0x00000000ff240010, 0x00000000ff300000)  to   space 1792K,   0% used [0x00000000fef80000, 0x00000000fef80000, 0x00000000ff140000)  -Xmn7m 用于配置新生代的大小  */  /**   * -XX:+PrintGC -Xmx20m -Xms20m -XX:+UseSerialGC -XX:+PrintGCDetails -XX:SurvivorRatio=2-Xmn7m -XX:NewRatio=2   *    * def new generation   total 5376K, used 3209K [0x00000000fec00000, 0x00000000ff300000, 0x00000000ff300000)  eden space 3584K,  60% used [0x00000000fec00000, 0x00000000fee224b8, 0x00000000fef80000)  from space 1792K,  57% used [0x00000000ff140000, 0x00000000ff240010, 0x00000000ff300000)  to   space 1792K,   0% used [0x00000000fef80000, 0x00000000fef80000, 0x00000000ff140000) tenured generation   total 13312K, used 547K [0x00000000ff300000, 0x0000000100000000, 0x0000000100000000)  the space 13312K,   4% used [0x00000000ff300000, 0x00000000ff388f80, 0x00000000ff389000, 0x0000000100000000)    -XX:NewRatio=2= tenured generation /def new generation    */byte[] b=null;for(int i=0;i<10;i++) {b=new byte[1*1024*1024];}}}
9,heap溢出处理

package com.wpx.demo01;import java.util.Vector;/** *  * @author wangpx */public class demo03 {public static void main(String[] args) {//-Xms5m -Xmx5m  -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=d:/demo03.dump/** * java.lang.OutOfMemoryError: Java heap spaceDumping heap to d:/demo03.dump ...Heap dump file created [1272762 bytes in 0.072 secs]Exception in thread "main" java.lang.OutOfMemoryError: Java heap spaceat com.wpx.demo01.demo02.main(demo02.java:48) */Vector v=new Vector();for(int i=10;i>0;i--) {v.add(new Byte[2*1024*1024]);}}}

-Xss 栈参数

package com.wpx.demo01;/** * -Xss2m 栈参数 *  第12381树第12382树Exception in thread "main" java.lang.StackOverflowErrorat sun.nio.cs.ext.DoubleByte$Encoder.encodeLoop(DoubleByte.java:617)at java.nio.charset.CharsetEncoder.encode(CharsetEncoder.java:579)at sun.nio.cs.StreamEncoder.implWrite(StreamEncoder.java:271)at sun.nio.cs.StreamEncoder.write(StreamEncoder.java:125)at java.io.OutputStreamWriter.write(OutputStreamWriter.java:207)at java.io.BufferedWriter.flushBuffer(BufferedWriter.java:129) * @author wangpx */public class demo04 {private static int count;public static void tree() {count++;System.out.println("第"+count+"树");tree();}public static void main(String[] args) {tree();}}
其实递归是极其糟糕的

package com.wpx.demo01;/** * -Xss2m 栈参数 *  * @author wangpx */public class demo04 {private static int count;public static void tree() {count++;System.out.println("第"+count+"树");}public static void main(String[] args) {while(true) {tree();}}}



-XX:PermSize  -XX:MaxPermSize






原创粉丝点击