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. 在Rancher 1.6上部署Traefik负载均衡器

    一.给Traefik主机打标签 01-给即将部署Traefik的主机节点打上标签.jpg 02-主机打完traefik_lb标签后的状态.jpg 二.在Rancher应用商店中部署Traefik 应用 ...

  2. git与github工具使用

    这篇文章主要的目标是用较少的时间学习Git和GitHub的基本使用.在足够一般使用的前提下,尽量减少命令.如果需要其他命令,到时候再去其他地方了解就行了. 总概:所有命令前都要加 git,如下的ini ...

  3. pgRouting新增扩展

    环境依赖:postgresql cgal boost perl 环境变量: boost环境变量 CGAL环境变量 postgresql环境变量 1.新建C++ 空项目 2,添加common引用,更改配 ...

  4. jquery 点击显示更多

    点击显示更多 html <div class="servicepicture banxin"> <div class="imgcontent" ...

  5. 『Python』为什么调用函数会令引用计数+2

    一.问题描述 Python中的垃圾回收是以引用计数为主,分代收集为辅,引用计数的缺陷是循环引用的问题.在Python中,如果一个对象的引用数为0,Python虚拟机就会回收这个对象的内存. sys.g ...

  6. 记录下用axios遇到的问题

    这两天用axios做页面登录.遇到了N多问题,.首先是报Response to preflight request doesn't pass access control check: No 'Acc ...

  7. 【Mybatis】【3】mybatis Example Criteria like 模糊查询

    正文: 在Java中使用Mybatis自动生成的方法,like需要自己写通配符 public List<TableA> query(String name) { Example examp ...

  8. 客户端与服务器之间通信收不到信息——readLine()

    写服务器端和客户端之间通信,结果一直读取不到信息,在https://blog.csdn.net/yiluxiangqian7715/article/details/50173573 上找到了原因:使用 ...

  9. CentOS 7 配置nginx并默认强制使用https对http进行跳转

    1.安装nginx yum install nginx 2.启动nginx服务 service nginx start 3.开启防火墙80端口,云服务器和本地虚拟服务器各有不同,不再赘述. 4.访问你 ...

  10. git(二) 分支管理

    概念 分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习SVN. 如果两个平行宇宙互不干扰,那对现在的你也没啥影响.不过,在某个时间点,两个平行宇 ...