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

Java 内存区域与内存溢出异常

[JVM] Java 内存区域与内存溢出异常 @TOC 手机用户请 横屏获取最佳阅读体验, REFERENCES中是本文参考的链接,如需要链接和更多资源,可以关注其他博客发布地址。...可能是一个指向对象的起始地址的引用指针,也可能是个指向一个对象的句柄或其他与此对象相关的位置)和returnAddress类型(指向了一条字节码指令的地址) 该区域根据Java虚拟机规范中,定义了两种异常情况...该区域和虚拟机栈抛出的异常情况一样。 Java 堆 Java 堆是Java虚拟机所管理的内存中最大的一块。被所有线程共享的一块区域,几乎所有的对象实例都在这里分配内存。...既然属于方法区的一部分,异常抛出和方法区一致。 直接内存 直接内存(Direct Memory)并不是虚拟机运行时数据区的一部分,也不是Java虚拟机规范中定义的内存区域。...但是,该内存的分配会受到本地内存总量的限制,服务器管理员在配置虚拟机参数时,可以根据实际内存设置 -Xmx等参数信息来调整堆的内存容量,来控制直接内存可以分配的最大容量。

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

Java内存区域与内存溢出异常

Java内存区域与内存溢出异常 运行时数据区 方法区(Method Area) 虚拟机栈(VM Stack) 本地方法栈(Native Method Stack) 堆(Heap) 程序计数器(PC) ?...Undefined) 虚拟机栈(VM Stack) 重点: 线程创建会同步创建Stack Frame(存储局部变量表[基本数据类型、对象引用]) 方法的调用和执行对应栈帧再虚拟机栈中入栈和出栈的过程 这个内存区域内规定的两类异常状况...OutofMenoryError(栈扩展失败) 我的理解:假设栈帧里面的方法是死循环,导致栈帧耗光了JVM栈的容量,此时产生OOM异常。...可扩展(通过参数-Xmx和-Xms设定) 这个内存区域可能产生的异常状况: OutofMenoryError **产生原因:**Java堆中没有内存完成实例分配 方法区 重点: 线程共享 存储类型信息...直接内存(不了解) 总结 掌握java内存区域布局,以及每一块的作用,知道每个内存区域时干什么的

2.2K60

Java常见内存溢出异常分析

.. args){       OOMTest oom = new OOMTest();       oom.stackOverFlowMethod();   }   } 运行上面的代码,会抛出如下的异常...JVM进行了一次Minor gc和两次的Major gc,从Major gc的输出可以看出,gc以后old区使用率为134K,而字节数组为10M,加起来大于了old generation的空间,所以抛出了异常...,如果调整-Xms21M,-Xmx21M,那么就不会触发gc操作也不会出现异常了。...通过上面的实验其实也从侧面验证了一个结论:当对象大于新生代剩余内存的时候,将直接放入老年代,当老年代剩余内存还是无法放下的时候,出发垃圾收集,收集后还是不能放下就会抛出内存溢出异常了 持久带溢出(OutOfMemoryError...使用一些应用服务器的热部署的时候,我们就会遇到热部署几次以后发现内存溢出了,这种情况就是因为每次热部署的后,原来的class没有被卸载掉。

1.2K70

JVM学习笔记——Java内存区域与内存溢出异常

这个区域有两种异常情况:线程请求的栈深度>JVM允许的深度,导致stackoverflow错误; 扩展时无法获取足够的内存,导致OutOfMemoryError错误。...直接内存 这部分并不是虚拟机运行数据区的一部分,也不是JVM规范中定义的内存区域。虽然本机直接内存的分配不会受到java堆的影响,但是还会受到本机总内存以及处理器寻址空间的限制。...指针碰撞:假设java堆中内存是绝对规整的,中间放着一个指针作为分界点的指示器,分配内存只需把指针向空闲空间那边移动一段与对象大小相等的距离。...空闲列表:内存不规整,虚拟机必须维护一个表,记录哪些内存块是可用的,从中找到一块足够大的内存分配给实例。...有两种解决方案: 对分配内存空间的动作进行同步处理 把内存分配的动作按照线程划分到不同的空间中进行,即每个线程在java堆中预先分配一小块内存,称为本地线程分配缓冲(TLAB) 对象的内存布局 对象中的内存布局可以分为三个区域

63040

Java虚拟机内存管理(三)—内存异常

3、内存异常 虽然说有 Java 虚拟机帮助我们管理内存,但是在管理过程中仍然有内存异常的发生。除了前面内存划分中说到的程序计数器外,其他区域都有发生 OutOfMemoryError 异常的可能。...String[] args) { List list = new ArrayList(); // 死循环不断生成对象,并添加到 list 中, 直到占满...在使用 MAT 内存分析器工具之前,我们还要知道内存泄露和内存溢出的区别,我在前面没有将 OutOfMemoryError 异常翻译成内存泄露异常内存溢出异常,而是使用原本的英文,内存泄露和内存溢出只是导致出现异常的原因...栈的深度是由栈的内存空间决定的,请求的栈越深,也即是已使用的栈的空间越大,所以上面 Java 虚拟机规范中的两种异常是有重叠之处的,一种异常也可能会导致另外一种异常的发生,到底是栈的内存空间太小引起的内存异常还是已使用的栈的内存空间太大引起的内存异常...直接内存异常.jpg

66031

Java虚拟机内存分区域与内存溢出异常

java虚拟机所管理的内存分为以下几个运行时数据区域。 Ⅰ程序计数器:当前线程所执行的字节码的行号指示器。...这类伴随线程存储的内存区域,称为线程私有的内存。 ⅡJavax虚拟机栈:很多刚学Java的学生通常会把Java内存区域分为堆和栈,这种分法比较粗糙,其中所指的栈就是现在所看的虚拟机栈。...举个例子说就是,在Java虚拟机运行一个方法时,方法内部的变量就是存储在Java虚拟机栈这个内存区域中,当然也是伴随这个方法的结束,其中的内存就释放了,也就是伴随着线程的内存区域,时线程私有的。...重点说下,关于这里的内存溢出问题,Java堆空间扩展方法, 通过-Xmx 和-Xms 控制,最好时设置成最小的和最大空间一样,并且为物理内存的四分之一。显而易见,对象实例存放的内存时线程共享的。...主要的内存区域就是这么几块。关于内存异常(OOM) 会放在下篇内容说明。

54620

服务器内存监测

而对于程序员而言,如何避免内存泄漏也是一门学问,倘若不加以控制,那么无论多大的内存都会有消耗殆尽的那天。...本文当然不是研究如何分析内存泄漏的产生原因与解决方案,而是在此之前的一步,通过简单的内存监测方式来预测内存泄漏的 潜在可能性 或者 偶发性 等。...我这边需要监测 系统内存 与 jvm堆内存 ,最终的结果会展示各个时间点的内存情况,所以需要一个时间类,表示每个切片的时间点。...timeMarkInterval是存储定时器id的,在销毁之前释放定时器;physicMemory和heapMemory获取图表div节点,用于echarts节点获取;systemInfo则会存储定时从服务器拉取到的数据...由图可见我这个系统堆内存通常消耗不到一百兆,后续可以将堆内存设定的再小一些,以提供给其它服务使用。总体内存是稳定状态,达到一定值会自动回收垃圾,占用率不会逐步提高,是个可控的系统。

11520

简述JVM基础(二):Java内存区域与内存溢出异常

但是我们经常面临的一个问题就是内存泄漏,JVM无法完成回收工作,导致内存占用暴涨,最后可能让程序奔溃。本章主要了解下运行时数据区域分布情况以及溢出异常。...没有内存完成实例分配,或者不能再扩展,报OutOfMemoryError异常 可以自己配置大小(-Xmx和-Xms) 5、方法区 线程共享 目的:存储类信息、常量、静态变量、即时编译器编译后的代码等数据...; 该区内存回收目标:主要针对常量池的回收和对类型的卸载; 无法满足内存分配要求时,报OutOfMemoryError异常 6、运行时常量池 注意:运行时常量池属于方法区 目的:存储编译期生成的各种字面量和符号引用...异常 三、 直接内存 非运行时数据区域内存 Native函数分配堆外内存,堆内的DirectByteBuffer作为这块内存的引用 性能显著提高,避免了Java堆和native之间来回复制数据 四、 对象...如果,程序执行过程中没有足够的空间分配,就报对应的OOM异常。 小贴士 本文由原作者井方哥独家授权Open软件开发小组发布,著作权归原作者所有。如需转载请联系原作者申请授权。

64010

Java 内存溢出(OOM)异常完全指南

需要注意的是:即使有足够的物理内存可用,只要达到堆空间设置的大小限制,此异常仍然会被触发。...上面的代码直接运行可能很久也不会抛出异常,可以在启动时使用-Xmx参数,设置堆内存大小,或者在for循环后打印HashMap的大小,执行后会发现HashMap的size一直再增长。...在从服务器卸载应用程序时,当前的 Classloader 以及加载的class在没有实例引用的情况下,永久代的内存空间会被 GC 清理并回收。...当应用程序部署到服务器上的时:服务器创建一个 Classloader 实例来加载应用所有的类(包含相应的 JDBC 驱动)。...一台服务器可以创建的线程数依赖于物理配置和平台,建议运行下文中的示例代码来测试找出这些限制。

3.5K13

服务器内存监测

而对于程序员而言,如何避免内存泄漏也是一门学问,倘若不加以控制,那么无论多大的内存都会有消耗殆尽的那天。...本文当然不是研究如何分析内存泄漏的产生原因与解决方案,而是在此之前的一步,通过简单的内存监测方式来预测内存泄漏的 潜在可能性 或者 偶发性 等。...我这边需要监测 系统内存 与 jvm堆内存 ,最终的结果会展示各个时间点的内存情况,所以需要一个时间类,表示每个切片的时间点。...timeMarkInterval是存储定时器id的,在销毁之前释放定时器;physicMemory和heapMemory获取图表div节点,用于echarts节点获取;systemInfo则会存储定时从服务器拉取到的数据...由图可见我这个系统堆内存通常消耗不到一百兆,后续可以将堆内存设定的再小一些,以提供给其它服务使用。总体内存是稳定状态,达到一定值会自动回收垃圾,占用率不会逐步提高,是个可控的系统。

15040

linux服务器内存

早上到单位 发现服务器 mysql 服务器停了 然后起来了 查询日志 显示 内存满了 把mysql服务给杀了 linux 服务器如果 内存满了 会自动清理进程 防止服务器挂掉 选择的话 谁占的的内存大...就先杀谁 我的服务器里面 mysql服务占的内存是最大的 所以就把mysql就给杀了 image.png 然后 重启mysql 查询内存 image.png 在这说一下 怎么看linux的内存 举个例子...空闲的内存数: 232M shared 当前已经废弃不用,总是0 buffers Buffer 缓存内存数: 62M cached Page 缓存内存数:421M 关系:total(1002M) = used...记住内存是拿来用的,不是拿来看的.不象windows, 无论你的真实物理内存有多少,他都要拿硬盘交换文件来读.这也就是windows为什么常常提示虚拟空间不足的原因.你们想想,多无聊,在内存还有大部分的时候...,拿出一部分硬盘空间来充当内存.硬盘怎么会快过内存.所以我们看linux,只要不用swap的交换空间,就不用担心自己的内存太少.如果常常 swap用很多,可能你就要考虑加物理内存了.这也是linux看内存是否够用的标准哦

31.8K10

JVM-03内存区域与内存溢出异常(下)【OutOfMemoryError案例】

接下来,我们来通过示例来演示下出现异常的场景。...,异常堆栈信息为java.lang.OutOfMemoryError 后面会跟着 Java heap space ---- 使用mat分析 要解决这个区域的异常,一般的手段是先通过内存映射分析工具比如Eclipse...关于虚拟机栈和本地方法栈,在Java虚拟机规范中描述了两种异常 如果线程请求的栈深度大于虚拟机所允许的最大深度,将抛出StackOverflowError异常 如果虚拟机在扩展栈时无法申请到最够的内存空间...,则抛出OutOfMemoryError异常 虽然把异常分成两种情况,看起来很严谨,其实却存在一些重叠的地方: 当栈空间无法继续分配时,是内存太小 还是已经使用的栈空间过大,本质上只是对同一件事情的两种描述而已...由于DirectMemory导致的内存溢出,一个明显的特征是在Heap Dump文件中不会看见明显的异常,如果发现OOM之后Dump很小,而程序中又直接或者间接的使用了NIO,那就可以考虑下是不是这个方面的原因

42620

内存管理--32:编写“异常安全代码”时留意内存管理问题

try{ //1:抛出异常的代码 //2:代码 }catch(){ //3:代码 //4:抛出异常 }finally{ //5:代码 } //6:代码 首先要明确的一点是:不管try是否抛出异常,finally...整个try,catch,finally执行有以下几种情况: 1:try语句块没有抛出异常。...如果是这种情况,程序会执行try,finally以及finally块之后的代码; 2:try语句块抛出了异常并且catch有匹配的异常。...第一种,抛出的异常被后面的catch捕获,而catch又没有抛出新的异常,那么执行顺序是1356 ;第二种,如果catch里面又抛出新的异常,顺序是1345,然后将新的异常返回给方法调用者,6就不执行了...; 3:try语句块抛出了异常,但是后面的catch没有能匹配的异常

8410
领券