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
- JVM 参数
- jvm参数
- jvm参数
- JVM 参数
- jvm 参数
- JVM参数
- jvm参数
- JVM参数
- jvm参数
- jvm参数
- JVM参数
- Jvm参数
- jvm参数
- jvm 参数
- JVM参数
- jvm 参数
- JVM参数
- jvm参数
- MyBatis缓存(Cache)
- 基本积分表
- WebAPI从Post的Body中解析出JObject格式的Request参数
- 判断网络状态是否可用
- std::multiset 的使用
- jvm参数
- poj 2891
- Chrome谷歌浏览器中js代码Array.sort排序的bug乱序解决办法
- Revit二次开发之快速过滤与慢速过滤【比目鱼原创】
- SVM To Face Recognize
- hdu4790 Just Random
- Rhyme/Quick Sort 快速排序Java版
- 开始学习android开发
- [ZJOI2006]书架 Treap