首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

jdk(4) - JVM内存

JVM 运行时内存划分 1.1 整体分布 主要分为 : jvm 内存 计数器 : 利用自增特性,主持线程顺次执行栈中的指令; JVM栈 : 由栈帧组成,每个栈帧包含当前方法的入口,返回信息,参数和变量...,基础类型和对象的引用等; 本地方法栈 : 主要维护JNI相关的信息 堆 : 用于存放程序运行中创建的对象数据; 本地内存 元数据区 : 用于存放永久对象的区域; 直接内存 : 用于存放堆外内存,...直接使用操作系统本身内存的区域(如 NIO部分类库实例); image.png 图中,绿色为线程私有的,换色则属线程公用; 1.2 堆内存划分 年轻代 Eden : 新对象的存放之地;占用内存达到阈值后会触发...servivor0 : 幸存区,用于youngGC时,临时存放幸存的对象; servivor1 : 同servivor0; servivor0, servivor1 配合Eden,使得youngGC时,不产生内存碎片...,同时保证了新生内存都在Eden区; 参考文章 : 为什么JVM新生代中有两个survivor?

64410
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    什么是虚拟内存?服务器虚拟内存怎么设置最好?

    ,虽然硬盘在读写的速度上远远不及内存条的速度,但是可以有效的避免内存消耗殆尽而引起的系统崩溃的问题而往往在运行大型或者一些或者吃内存的软件程序的时候就有可能会出现虚拟内存不足的情况二、怎么设置服务器虚拟内存...虚拟内存设置多少合适? ...这样设置只是把系统默认在系统盘的虚拟内存设置成无了5、把系统盘的虚拟内存设置成无之后,就需要把虚拟内存设置在其他盘了,然后选择所要设置的盘符 假设设置在D盘,选择D盘之后,再选择自定义大小(C)项,在初始大小文本框里填写...:2048  这个2048是按照系统内存来写的,比如内存2G也就是2048MB的内存 ,虚拟内存最好是和系统内存大小是一样的,最大值建议是初始大小的1.5倍到2倍的样子6、设置好后确定,设置好后重启服务器就会生效了注意...:为了保证网站正常运行,服务器虚拟内存不要使用默认配置,需要设置一下,一般设置为2G-10G以上就是关于虚拟内存设置分享感谢您的阅读,服务器大本营助您成为更专业的服务器管理员!

    52510

    什么是虚拟内存,云服务器设置虚拟内存应该怎样操作?

    为了避免这种情况,不少人已经开始用云服务器设置虚拟内存了,我们一起来了解是怎么回事吧。 什么是虚拟内存 要知道云服务路设置虚拟内存怎么操作,首先我们要知道什么是虚拟内存。...怎么设置 云服务器设置虚拟内存要怎样操作呢?具体步骤如下:一、在“我的电脑”图边上点击右键,然后就能看到一个系统属性的窗口。二、调出系统属性之后,找到“高级”选项,然点击性能下面的“设置”按钮。...三、打开设置按钮后,会弹出一个性能选项窗口,点击“高级”,这时候就能看到高级选项卡,然后点击高级选项卡下面的“更改”。四、这时候再打开设置时,就会弹出一个虚拟内存的窗口。...到这一步我们就可以根据自己的需求进行设置了,设置完之后重启即可。 通过以上介绍,对于云服务器设置虚拟内存怎么操作,想必大家已经有所了解了。...如果想了解更多关于云服务器的设置虚拟内存的信息,可以自己尝试着操作一下。

    18.8K10

    Java内存管理-JVM内存模型以及JDK7和JDK8内存模型对比总结(三)

    JDK1.4中新引入了NIO机制,它是一种基于通道与缓冲区的新I/O方式,可以直接从操作系统中分配直接内存,即直接堆外分配内存,这样能在一些场景中提高性能,因为避免了在Java堆和Native堆中来回复制数据...三、JDK7和JDK8的JVM内存模型的总结 1、方法区变化 这里介绍的是JDK1.8 JVM内存模型。...方法区只是JVM规范定义,而永久代为具体的实现,元空间也是方法区在jdk1.8中的一种实现。 2)为什么废除永久代?...2、运行时常量池变化 在近三个JDK版本(1.6、1.7、1.8)中, 运行时常量池(Runtime Constant Pool)的所处区域一直在不断的变化,在JDK1.6时它是方法区的一部分;1.7又把他放到了堆内存中...五、参考内容 《深入理解Java虚拟机》 JDK1.8 JVM内存模型 Java内存区域与内存溢出异常(jdk 6,7,8) 对于JVM内存模型的理解(对比jdk1.7与1.8) https://www.cnblogs.com

    1.6K20

    JDK环境变量设置详解

    一、JDK安装完成之后我们进行完整的JDK环境变量设置: 我的电脑点右键,选择“属性”,选择“高级”标签,进入环境变量设置,分别设置如下三个环境变量: (1)设置JAVA_HOME: 一是为了方便引用...,比如,JDK安装在C:\jdk1.6.0目录里,则设置JAVA_HOME为该目录路径, 那么以后要使用这个路径的时候,只需输入%JAVA_HOME%即可,避免每次引用都输入很长的路径串; 二则是归一原则...在系统环境变量那一栏中点->新建JAVA_HOME (JAVA_HOME指向的是JDK的安装路径)    变量名:JAVA_HOME    变量值:C:\jdk1.6.0 (2)设置好path变量...,使得我们能够在系统中的任何地方运行java应用程序,比如javac、java、javah等等,这就要找到我们安装JDK的目录,比如我们的JDK安装在C:\jdk1.6.0目录下,那么在C:\jdk1.6.0...二 、一种简单的jdk设置: 只在环境变量中设置一个path变量,在前面添加一个C:\jdk1.6.0\bin;  变量名:PATH      变量值:C:\jdk1.6.0\bin; 直接在命令提示符中运行

    1.2K30

    jdk1.7和jdk1.8的堆内存模型

    jdk1.7的堆内存模型 Young 年轻区(代) Young区被划分为三部分,Eden区和两个大小严格相同的Survivor区,其中,Survivor区间中,某一时刻只有其中一个是被使用的,另外一个留做垃圾收集时复制对象用...Perm 永久区 Perm代主要保存class,method,filed对象,这部份的空间一般不会溢出,除非一次性加载了很多的类,不过在涉及到热部署的应用服务器的时候,有时候会遇到java.lang.OutOfMemoryError...PermGen space 的错误,造成这个错误的很大原因就有可能是每次都重新部署,但是重新部署后,类的class没有被卸载掉,这样就造 成了大量的class对象保存在了perm中,这种情况下,一般重新启动应用服务器可以解决问题...Virtual区: 最大内存和初始内存的差值,就是Virtual区。 jdk1.8的堆内存模型 由上图可以看出,jdk1.8的内存模型是由2部分组成,年轻代+ 年老代。...年轻代:Eden + 2*Survivor 年老代:OldGen 在jdk1.8中变化最大的Perm区,用Metaspace(元数据空间)进行了替换。

    85220

    Java堆内存设置

    (jvm启动时分配的内存) -Xmx1024m (jvm运行过程中分配的最大内存) -Xmn256m (新生代大小) -Xss256k (jvm启动的每个线程分配的内存大小,默认JDK1.4中是256K...=128m (元空间默认大小) -XX:MaxMetaspaceSize=128m (元空间最大大小) JDK 8开始把类的元数据放到本地化的堆内存(native heap)中,这一块区域就叫Metaspace...,但需要注意的是这个参数是在JDK1.4版本以后才使用的。...-Xss256k: jvm启动的每个线程分配的内存大小,默认JDK1.4中是256K,JDK1.5+中是1M 非堆设置 JDK7及以前 -XX:PermSize=128M 表示非堆区初始内存分配大小...,其缩写为permanent size(持久化内存) -XX:MaxPermSize=256M 表示非堆区最大内存分配大小 JDK8及以后 -XX:MetaspaceSize=128m (元空间默认大小

    3.2K20

    JVM之JVM运行时内存结构, JDK1.7 JVM内存结构, JDK1.8 JVM内存结构, JVM堆内存结构

    1 JDK1.7结构 1.1 JVM内存图 程序计数器: 线程私有的(每个线程都有一个自己的程序计数器), 是一个指针. 代码运行, 执行命令....方法区: 线程共享的(所有的线程共享一份), .class的信息, 类的信息, 方法的定义, 常量池, 静态变量等. 1.2 JDK1.7 堆内存结构 Young 年轻区(代) Young区被划分为三部分...PermGen space 的错误,造成这个错误的很大原因就有可能是每次都重新部署,但是重新部署后,类的class没有被卸载掉,这样就造成了大量的class对象保存在了perm中,这种情况下,一般重新启动应用服务器可以解决问题...JDK1.8 结构 2.1 JVM运行时内存图 JDK1.8和JDK1.7的jvm内存最大的区别是, 在1.8中方法区是由元空间(元数据区)来实现的,常量池移到堆中. 1.8不存在方法区,将方法区的实现给去掉了...元空间: 存储.class 信息, 类的信息,方法的定义,静态变量等.而常量池放到堆里存储 2.2 JDK1.8堆内存结构 由上图可以看出,jdk1.8的内存模型是由2部分组成, 年轻代+年老代.

    83210

    Java 内存泄漏分析和对内存设置

    为了判断 Java 中是否有内存泄漏,我们首先必须了解 Java 是如何管理内存的。...内存不足会有三种情况: 对内存不足 本地内存不足 Perm 内存不足 发生 OOM 的时候,可以检查如下几个方面: 应用程序的缓存功能 大量长期活动对象 对内存泄漏 本地内存泄漏 2.2 内存泄漏的症状...堆内存不足的原因有如下几种: 堆内存设置太小 内存泄漏 设计不足,缓存了多余的数据 如果怀疑有内存泄漏,可以添加 -verbose:gc 参数后重现启动 Java 进程,输出大致如下: ?...步骤如下: 获取系统稳定后的 GC 日志(不稳定的日志不可靠) 过滤 FullGC 日志,可能会有如下两种情况 FullGC 后内存使用量持续增长,一直到设置的堆内存最大值,基本可以确定内存泄漏 内存使用量增长后又回落...本地内存泄漏的原因有如下几个: JNI 调用中出现内存泄漏(JNI 调用出现内存泄漏,可以使用 C/C++ 内存泄漏分析方法定位) JDK bug 操作系统问题 本地内存泄漏可能伴有如下异常 ?

    1.7K22

    JDK1.9-数组原理内存图

    2.1 内存概述 内存是计算机中的重要原件,临时存储区域,作用是运行程序。我们编写的程序是存放在硬盘中的,在硬盘中的程 序是不会运行的,必须放进内存中才能运行,运行完毕后会清空内存。...Java虚拟机要运行程序,必须要对内存进行空间的分配和管理。 2.2 Java虚拟机的内存划分 为了提高运算效率,就对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式。...JVM的内存划分: 2.3 数组在内存中的存储 一个数组内存图 以上方法执行,输出的结果是[I@5f150435,这个是什么呢?是数组在内存中的地址。...new出来的内容,都是在堆 内存中存储的,而方法中的变量arr保存的是数组的地址。 输出arr[0],就会输出arr保存的内存地址中数组中0索引上的元素 两个数组内存图

    23940

    eclipse.ini 内存设置

    参数中-vmargs的意思是设置JVM参数,所以后面的其实都是JVM的参数了,我们首先了解一下JVM内存管理的机制,然后再解释每个参数代表的含义。...因此服务器一般设置-Xms、-Xmx相等以避免在每次GC 后调整堆的大小。 ...非堆内存分配 JVM使用-XX:PermSize设置非堆内存初始值,默认是物理内存的1/64;由XX:MaxPermSize设置最大非堆内存的大小,默认是物理内存的1/4。 ...如果你有一个双核的CPU,也许可以尝试这个参数: -XX:+UseParallelGC 让GC可以更快的执行(只是JDK 5里对GC新增加的参数) eclipse.ini 示例(16G物理内存): -startup...eclipse.ini/myeclipse.ini中配置参数 -Xms,-Xmx,-PerSize Eclipse.ini参数设置(Maven Integration for Eclipse JDK

    1.8K20
    领券