DAY 1

Jvm- java虚拟机

  1. 类加载子系统
    1. 加载class文件到方法区
  2. 方法区
    1. 存放类信息
    2. 常量信息
    3. 常量池信息
    4. 辅助堆栈的永久区,解决堆栈信息的产生,是先决条件

  3.  Java堆(重要)

    1. 虚拟机启动的时候建立
    2. 最主要的内存工作区域
    3. 几乎所有的对象实例都存放到Java堆中,堆内存是所有的线程共享的
    4. 解决数据存储的问题

  4.    直接内存

    1. Java的NIO库允许java程序使用直接内存,从而提高性能,速度优于JAVA堆
    2. 读写频繁可考虑使用

  5. Java栈

    1. 线程创建的时候被创建
    2. 保存局部变量、方法参数、引用、java方法的调用、返回值等
    3. 解决数据运行问题

  6. 本地方法栈(不重要)

  7. 垃圾回收系统(重要)

    1. GC垃圾回收系统

  8. PC寄存器(不重要)

    1. 保存一些指针

  9. 执行引擎

    1. 负责执行虚拟机的字节码

堆栈方法区详细

Java堆(核心)

Java堆完全自动化管理,通过垃圾回收机制自动清理,不需要显示的释放。

Java堆如何划分?(面试)

通常分为新生代和老生代,其中新生代存放新生的对象,老的存放老的对象。

新生代:eden区(对象刚实例化的状态)、S0(from)区、S1(TO)区(s0\s1大小相等、可相互转换的角色)

对象通常先分配到eden区,在一次GC后,如果对象还在,那么进去s0或者s1区,后面没经历一次GC年龄加1,到达一定的年龄后,进入老年代。

新生代中GC的频率会比老年代高很多。

Java栈(不是特别重要)

线程私有的内存空间。

局部变量表:报错信息

操作数栈:计算过程中的临时变量

帧数据区:报错信息

方法区:

如果系统定义太多的类,可能会导致方法区溢出。

虚拟机参数:

堆分配参数(一)(+启用,-禁用)

(1)  -XX 对于系统级别的(JVM)配置,配置日志信息或者说配置JVM使用什么样的垃圾回收器。

(2)非-XX的基本上都是对应用层面上的配置。

+启用   -禁用

-XX:+PrintGC使用这个参数,虚拟机启动后,只要遇到GC就会打印日志。

-XX: +UseSerialGC配置串行回收器

-XX:+PrintGCDetails可以查看详细信息,包括各个区的情况

-Xms:设置java程序启动时初始化堆大小

-Xmx: 设置java程序能获得的最大堆大小。

-XX:+PrintCommandLineFlags:可以将隐式或者显示传给虚拟机的参数输出

初始值与最大值配置的一样可减少GC的回收次数。

新生代配置:

Xmn:设置新生代的大小,这个参数对GC行为有很大的影响,占整个堆空间的1/3到1/4左右。

-XX:用来设置新生代中eden空间和from/to空间的比例,含义-XX:SurvivorRatioe=eden/from=eden/to

实例2:

不同的堆分布情况,对系统执行会产生一定的影响,在实际工作中,应该根据系统的特点做出合理的配置,基本策略:尽可能将对象预留在新生代,减少老年代的GC次数。除了可以设置新生代的绝对大小(-Xmn),还可以使用(-XX:NewRatio)设置新生代和老年代的比例:-XX:NewRatio=老年代/新生代

堆溢出处理:

如下的配置可将溢出的信息打印到路径下,可copy文件到eclipse下的memory analyer插件查看

-Xss指定线程的最大栈空间,参数决定了函数可调用的最大深度

方法区:

和java堆一样,是所有线程共享的内存区域,它用于保存系统的类信息,可以保存多少信息可以对其进行配置,在默认情况下,-XX:MaxPremSize为64MB,如果系统运行时生产大量的类就需要设置一个相对合适的方法区,以避免永久区内存溢出。

直接内存配置:

广泛用在NIO中,直接跳过java堆。

垃圾回收概念和其算法:

垃圾回收有很多算法:如引用计数法、标记压缩法、

引用计数:被引用+1 失去引用 -1  遇到循环或者递归浪费性能。

标记清除法:被标记的时候由于JVM不会清除完全,会有碎片的问题。比如1M需要标志清除,但是可能JVM只能清除0.999M。

复制算法(新生代)   from区to区相互转换角色。

标记压缩法(老年代):在标记清除的基础下进行压缩,压缩到内存的一端进行清除防止碎片的问题。

分代算法:根据对象的特点把内存分为N块,而后根据每个内存的特点使用不同的算法。

分区算法:oracle新的概念,主要讲整个内存分为N多个小的独立空间,每个小空间都可以独立使用。减少GC停顿。

GC停顿:GC回收的时候会让所有应用的线程进入停顿状态,回收完成后再继续。

对象如何进入老年代:

-XX:MaxThnuringThreshold, 默认15次。

-XX:PretenureSizeThreshold指定进入老年代的对象大小。要注意TLAB区域优先分配空间。

TLAB:每一个线程都会产生一个TLAB区,为了加速对象分配而生的。每一个TLAB区来避免多线程冲突的问题,提高对象分配的效率。一般不会太大。

-XX:+UseTLAB使用TLAB区。默认使用。

JVM概念以及常用设置的更多相关文章

  1. WebSphere常用设置

    WebSphere常用设置 1.查看环境配置信息D:\Program Files\IBM\WebSphere\AppServer\profiles\AppSrv01\logs\AboutThisPro ...

  2. JVM基础(6)-常用参数总结

    参考文章: 并发编程网:http://ifeve.com/useful-jvm-flags-part-4-heap-tuning/ 一.参数分类 HotSpot JVM 提供了三类参数. 第一类包括了 ...

  3. HTML head标签内部常用设置

    HTML head标签内部常用设置 在网页html文件中,head标签里面通常放置的代码是用来对网页进行相关设置的内容.下面就是对这些内容的介绍. meta标签的设置 在网页中,meta标签最常用的设 ...

  4. Java基础-考察JVM内部结构的常用工具介绍

    Java基础-考察JVM内部结构的常用工具介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 我们可以通过jvisualvm.exe考察jvm内部结构.而jvisualvm.exe ...

  5. composer 基本概念与常用命令总结

    目录 composer 基本概念与常用命令总结 基本概念 软件安装 linux/mac安装 windows 配置镜像 如何使用 常用命令 全局参数 初始化 init 初始化参数 依赖安装 instal ...

  6. Matplotlib数据可视化(2):三大容器对象与常用设置

      上一篇博客中说到,matplotlib中所有画图元素(artist)分为两类:基本型和容器型.容器型元素包括三种:figure.axes.axis.一次画图的必经流程就是先创建好figure实例, ...

  7. PLSQL Developer常用设置及快捷键

    CSDN日报20170314--<40岁程序员真的要被淘汰了么?> 程序员2月书讯 [直播]用面向协议的思想简化网络请求 博客一键搬家活动开始啦 PLSQL Developer常用设置及快 ...

  8. pycharm快捷键及一些常用设置

    pycharm快捷键及一些常用设置,有需要的朋友可以参考下. Alt+Enter 自动添加包 Ctrl+t SVN更新 Ctrl+k SVN提交 Ctrl + / 注释(取消注释)选择的行 Ctrl+ ...

  9. PLSQLDeveloper 常用设置

    PLSQL Developer常用设置及快捷键   1.登录后默认自动选中My Objects (已验证可用)   默认情况下,PLSQL Developer登录后,Brower里会选择All obj ...

随机推荐

  1. PyQt5——布局管理

    PyQt5布局管理使用方法详见:https://blog.csdn.net/jia666666/article/list/3?t=1& PyQt5布局管理汇总: 1.QHBoxLayout 2 ...

  2. vue 双向绑定 数据修改但页面没刷新

    在数据改动的代码后加 this.$forceUpdate(); 若是在某个特定方法中 则将this改为方法中设定的名称

  3. UML作业第二次:类在类图中的表示

    一.学习小结: 类之间的关系通过下面的符号定义 : 使用.. 来代替 -- 可以得到点 线. @startuml Class01 <|-- Class02 Class03 *-- Class04 ...

  4. 初步接触gulp

    首先是安装nodejs,通过nodejs的npm全局安装和项目安装gulp,其次在项目里安装所需要的gulp插件,然后新建gulp的配置文件gulpfile.js并写好配置信息(定义gulp任务),最 ...

  5. 在java程序代码中打开文件

    class     TEST {      public  static  void  main(String[]  args){        System.out.println("He ...

  6. 【转】PO/POJO/BO/DTO/VO的区别

      PO :persistent object持久对象 1 .有时也被称为Data对象,对应数据库中的entity,可以简单认为一个PO对应数据库中的一条记录. 2 .在hibernate持久化框架中 ...

  7. springcloud-spring cloud config统一配置中心

    统一配置中心 为什么需要统一配置中心? 统一配置中心顾名思义,就是将配置统一管理,配置统一管理的好处是在日后大规模集群部署服务应用时相同的服务配置一致,日后再修改配置只需要统一修改全部同步,不需要一个 ...

  8. EXCE 表格导入导出遇到问题(easypoi)

    使用Easypoi进行excel表格的导入导出遇到的问题: 1.导出时候打开文件一直遇乱码,主要的原因就是我在实体类没有进行给每个字段进行注解,就会导致每个字段找不到对应的汉字表头,所以一定不要忘了导 ...

  9. 在Debian9服务器上安装最新版Python

    通过Xshell 6 远程连接linux服务器 安装前的准备工作 更新服务器: 命令:apt update && apt upgrade -y 安装python3的依赖库: 命令:ap ...

  10. ajax入门学习

    1.   XMLHttpRequest 是 AJAX 的基础. 所有现代浏览器均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject). XMLHttpReq ...