1 、说起jvm,很多人感觉jvm离我们开发实际很远。但是,我们开发缺每时每刻都离不开jvm。

     a: java源码 编译后成.class字节码文件,

     b:根据classpath找到这个字节码文件,

     c:然后 用类加载器classloader加载文件。

  经过上面三步后,JVM开始解释执行。

 

  栈:程序运行单位,与当前线程有关内容(局部分量、程序运行状态、方法返回值);

  堆:Java引用传递实现依靠堆内存,同一堆空间可被不同栈内容内存指向;

  程序计数器:小空间,用于计数操作,解决对象晋升问题;

  本地方法栈:递归调用保存栈内容,局部变量表,操作数栈、当前类运行时常量的引用、返回地址。

  2、jvm堆拆分:关键在于堆优化,需清除Java对象访问模式,Java对象引用采用是hotspot的指针引用。

  一般我们会对堆进行拆分,年轻代+老年代+元空间。

   

   a、年轻代中含有 伊甸园区,存活区。

  伊甸园区一般有new对象创建出来的对象,存活区是进行GC后保存的对象,S0或S1存储,但是有一块空间永远是空的,对象向老年代晋升(程序计数器会计算GC次数)。

  如果伊甸园中创建的对象过多,伊甸园占满,会发生晋级操作-经过minorGc

     b、老年代存放又臭又硬的对象,经历无数次的GC后被保留下来的对象或者是对象很大,直接保存到老年代。这些对象清除困难。

  如果老年代出现空间不足,会发生majorGC(FullGc)。majorGC非常耗费整个系统性能。所以我们一般很少使用System.gc();

  3、jvm堆优化

  对堆结构添加伸缩区,当老年代或年轻代空间不足时,可对空间进行压缩或伸展。

  当堆内存空间很大的情况下,减少堆内存的收缩处理操作。就需要考虑到 GC 的执行效率问题。

    Runtime.getRuntime().maxMemory()   最大可用内存  默认大小为当前物理内存的“1 / 4”

    Runtime.getRuntime().totalMemory()   默认可用内存  默认大小为当前物理内存的“1 / 64”

   可使用 至关重要的两个参数-Xms和-Xmx:可以使用的单位(k、m、g)

       -Xms:设置初始化的内存分配大小;

      -Xmx:设置最大的可用内存空间。

    举例设值: -Xms16g -Xmx16g

  对于年轻代,有BTP和TLAB,BTP伊甸园最晚创建对象放栈顶,TLAB分块保存,多线程处理。  

        -Xmn:设置年轻代的空间大小,默认采用的时物理内存的“1 / 64”

        -Xss:设置每一个线程所占用的栈的线程大小

        -X:SurvivorRatio:设置伊甸园区与两个存活区之间的内存分配比,默认“8 : 1 : 1”  

  老年代:
    与年轻代比率:-XX:NewRatio 当对象很大的时候往往不在年轻代进行保存,而是直接晋级到老年代,利用“-XX:PretenureSizeThreshold”。

  元空间不在堆内存中,存在于物理内存中。

  

  4、GC算法:多线程执行

    复制-清理算法,将对象清理,递升存活区到老年代

    标记-清除-压缩,扫描老年代中的存活对象 ,并且进行对象的标记; 遍历整个老年代的内存空间,回收所有标记对象; 为了保证可以方便的

  计算出老年代的大小,还需要进行压缩(碎片整理,把空间集中在一起)。但是这种算法会有一个严重性的问题:STW(产生中断,因为需要进行垃圾的标记)  

      |- 暂停当前的所有执行程序(挂起);
      |- 标记出垃圾,标记的时间越长,那么挂起的时间就越长,如果此时你的堆内存空间很大,那么时间一定会更长;

      |- 预清除处理;

      |- 重新标记过程:看看还有没有垃圾;

      |- 进行垃圾的处理;
      |- 程序恢复执行。

   以前使用的:-Xms48

浅谈jvm的更多相关文章

  1. 浅谈jvm中的垃圾回收策略

    下面小编就为大家带来一篇浅谈jvm中的垃圾回收策略.小编觉得挺不错的,现在就分享给大家,也给大家做个参考.一起跟随小编过来看看吧   java和C#中的内存的分配和释放都是由虚拟机自动管理的,此前我已 ...

  2. 浅谈JVM线程调度机制及主要策略

    在之前有说过线程,应该都知道,所谓线程就是进程中的一个子任务,一个进程有多个线程.今天的话主要就是谈一谈JVM线程调度机制.我们结合线程来说,当我们在做多线程的案例时,如一个经典案例,火车站卖票. * ...

  3. 浅谈JVM垃圾回收

    JVM内存区域 要想搞懂啊垃圾回收机制,首先就要知道垃圾回收主要回收的是哪些数据,这些数据主要在哪一块区域. Java8和Java8之前的相同点有很多. 都有虚拟机栈,本地方法栈,程序计数器,这三个是 ...

  4. 浅谈JVM内存区域划分

    好吧,虽说真的有看过<深入分析Java Web技术内幕>一书,但当时看的时候还是一知半解,稀里糊涂的看完了.本来是打算暑假拿起来再看一遍的,但是早两天一个阿里学长给我做了个小面试,让我颇受 ...

  5. 浅谈JVM与内存分配

    一.程序内存分配 初始内存分配 当一个程序准备运行时,它首先向java虚拟机要内存,但是java虚拟机本身没有权限,它只能向操作系统申请内存,此时java虚拟机会拥有一个初始内存, 此处额外说明一下e ...

  6. 浅谈JVM编译原理->.java文件转变为.class文件的过程

    为什么需要编译? 我们平常写代码,有规范的命名方式,都能够看得懂,但是我们写的代码计算机是看不懂的,所以需要编译,也就是一个转换的过程,如下: 1.这个是咱们平时写的代码,就比较好理解,对人友好 2. ...

  7. 浅谈JVM内存模型

    JAVA虚拟机在执行JAVA程序的时候,会把它管理的内存分成若干不同的数据区域,每个区域都有各自的用途.目前大致把JVM内存模型划分为五个区域:程序计数器,虚拟机栈,本地方法栈,堆和方法区. 程序计数 ...

  8. 浅谈 JVM 结构体系、类加载、JDK JRE JVM 三者的关系

    一.java类,创建.编译.到运行的工程: 1.随便建一个Java类,保存后就是一个.java文件, 2.然后我们使用 javac命令编译 .java文件,生产 .class文件. 3.再然后使用 j ...

  9. 浅谈JVM及原理

    前言 JVM一直是java知识里面进阶阶段的重要部分,如果希望在java领域研究的更深入,则JVM则是如论如何也避开不了的话题,本系列试图通过简洁易读的方式,讲解JVM必要的知识点. 运行流程 我们都 ...

随机推荐

  1. Shell记录-Shell命令(定时任务)

    在Linux系统中, at 命令是针对仅运行一次的任务,循环运行的例行性计划任务,linux系统则是由 cron(crond) 这个系统服务来控制的.Linux 系统上面原本就有非常多的计划性工作,因 ...

  2. okhttp 简单用法

    1.gradle 依赖 github 中查找最新的 2.MyApplication oncreate 中: @Override public void onCreate () { super.onCr ...

  3. 监控Elasticsearch的插件【check_es_system】

    监控Elasticsearch的插件推荐  强大的shell脚本 #!/bin/bash ####################################################### ...

  4. [转载]WCF和ASP.NET Web API在应用上的选择

    http://www.cnblogs.com/shanyou/archive/2012/09/26/2704814.html http://msdn.microsoft.com/en-us/libra ...

  5. 20155117王震宇实验四 Andoid开发基础实验报告

    实验内容 1.Android Stuidio的安装测试: 参考<Java和Android开发学习指南(第二版)(EPUBIT,Java for Android 2nd)>第二十四章: - ...

  6. 【方法】jQuery无插件实现 鼠标拖动切换图片/内容 功能

    前言 我就想随便叨逼叨几句,爱看就看几句,不爱看就直接跳过看正文就好啦~ 这个方法是仿写页面时我自己研究出来,可能有比我更简单的方法. 但我不管,因为我没查我不知道,我就觉得我的最好啦,耶耶耶~ 效果 ...

  7. Oracle03--子查询

    1. 子查询 子查询也称之为嵌套子句查询. 1.1. 语法 语法上的运行使用规则: l 子查询 (内查询.嵌套子句) 在主查询之前一次执行完成.(子查询先执行) l 子查询的结果被主查询使用 (外查询 ...

  8. Oracle Certified Java Programmer 经典题目分析(二)

    ...接上篇 what is reserved(保留) words in java? A. run B. default C. implement D. import Java 关键字列表 (依字母排 ...

  9. ModelState验证部分属性

    ModelState.Remove("Name") 去掉不需要验证的属性.

  10. Centos 软连接和硬链接

    1.软链接: 建立软链接:ln -s /usr/local/node-v4.2.6-linux-x86/bin/node /usr/local/bin/node 解释:将/usr/local/node ...