直接上代码:

public class Test001 {
public static void main(String[] args) {
//java.lang.StackOverflowError 栈溢出错误, 这个是error 不是异常,因为StackOverflowError 是Error的子类
// 栈溢出, 递归方法,调方法
m1();
}
public static void m1(){
m1();
}
@Test
public void test02(){
// java.lang.OutOfMemoryError: Java heap space 堆溢出 这个是error Error的子类
// 堆溢出, 直接new 一个1G的大对象,就报异常了
ArrayList<int[]> list = new ArrayList<>();
while(true){
int[] ints = new int[1024];
list.add(ints);
}
//或者new 一个 大对象
//Object[] objects = new Object[1024 * 1024 * 1024];
}
}
class GC_OverHead_limit_demo1{
public static void main(String[] args) {
//jvm 参数设置: -Xms10m -Xmx10m -XX:+PrintGCDetails
// java.lang.OutOfMemoryError: GC overhead limit exceeded
// 这是错误
// 出现的原因: 执行垃圾回收的时间占比太大,实际工作时间太小, 默认情况下 GC话费时间超过98% ,并且垃圾回收的内存少于2%, 就会抛出此错误
int i = 0;
List<String> list = new ArrayList<>();
try {
while (true){
list.add(String.valueOf(++i).intern());
}
} catch (Exception e) {
System.out.println(i);
e.printStackTrace();
throw e;
}
}
} class Direct_buffer_memory_demo{
private static final int BUFFER = 1024*1024*20; //20M
public static void main(String[] args) { // 直接内存不属于 jvm 运行时数据区的一部分
// 对象存储的位置,不在jvm的堆中,而是在物理内存中(直接内存中,为内存的1/4), 这样直接内存中的对象不停增加,直到满了,而此时jvm 的 gc并不会执行,所以报这个错误
// java.lang.OutOfMemoryError: Direct buffer memory
// 怎样查看直接内存大小 sun.misc.VM.maxDirectMemory() /1024/1024 单位 m // jvm 参数:设置堆最大为10m, -Xms10m -Xmx10m -XX:+PrintGCDetails 可以设置直接内存,如果不设置 和堆空间最大值相同
System.out.println(VM.maxDirectMemory() / 1024 / 1024);// 直接内存大小为 9m
ByteBuffer byteBuffer = ByteBuffer.allocateDirect(10 * 1024 * 1024);//这里直接放10m 的缓存
}
} class Unable_to_create_new_native_Thread_demo{
public static void main(String[] args) throws InterruptedException {
// 这个是高并发情况下 容易爆出的生产上的错误
// java.lang.OutOfMemoryError: Unable_to_create_new_native_Thread
// 一个应用进程里 创建了过个线程,直接撑爆最大上限, linux服务器默认普通用户一个进程创建线程上限为1024, 如果是root用户则无上限
// 解决方案: 遇到这个错误,分析程序是否需要这么多线程,改代码, 或者修改服务器配置,增加创建线程上限
// https://www.jianshu.com/p/103589cea5f5
// https://blog.csdn.net/east4ming/article/details/80179670
//这里模拟一个 main线程下 创建多个线程
AtomicInteger count = new AtomicInteger();
while(true){
new Thread(()->{
try {
count.getAndIncrement();
System.out.println(count.get());
Thread.sleep(Integer.MAX_VALUE);
} catch (InterruptedException e) {
e.printStackTrace();
}
}).start();
}
//这个在win系统下 并没有测出错误结果, 在linux系统下 930多个就报错误了
}
} class MetaSpace_demo1{
static class OOM_Test{
//静态内部类
}
public static void main(String[] args) {
// 1.8之后,元空间取代了 永久代, 且元空间不在 jvm的 运行时数据区,而是使用的本地内存
// jvm参数: -XX:MetaspaceSize=8m -XX:MaxMetaspaceSize=10m
// 运行结果: 396 时候就报错误了; java.lang.OutOfMemoryError: Metaspace
/**
* 元空间 存放的信息:
* 1: 虚拟机加载的类信息
* 2: 常量池
* 3: 静态变量
* 4: 即使编译后的代码
*
* 所以: 不停地创建 静态类,存放到元空间,直到撑爆,报异常
*/
int i = 0;
try {
while(true){
i++;
//这里使用 cglib 生成代理类, 这个类是静态的,所以创建后放在元空间
//1, 创建工具类
Enhancer enhancer = new Enhancer();
//2, 设置父类
enhancer.setSuperclass(OOM_Test.class);
enhancer.setUseCache(false);//不使用缓存
//3, 设置回调函数
enhancer.setCallback(new MethodInterceptor(){
@Override
public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
return methodProxy.invokeSuper(o,args);
}
});
//4, 创建代理对象
Object o = enhancer.create();
}
} catch (Exception e) {
System.out.println(i);
e.printStackTrace();
} }
}

JVM--你常见的jvm 异常有哪些? 代码演示:StackOverflowError , utOfMemoryError: Java heap space , OutOfMemoryError: GC overhead limit exceeded, Direct buffer memory, Unable_to_create_new_native_Thread, Metaspace的更多相关文章

  1. java 异常 java.lang.OutOfMemoryError: GC overhead limit exceeded 解决

    一.异常如下: Exception in thread "main" java.lang.OutOfMemoryError: GC overhead limit exceeded ...

  2. AndroidStudio 编译异常java.lang.OutOfMemoryError: GC overhead limit exceeded

    在build.gradle中的android{}添加如下脚本就可以顺利编译了 dexOptions { incremental true javaMaxHeapSize “4g” }

  3. 记一次由于引用第三方服务导致的GC overhead limit exceeded异常

    最近笔者遇到一个问题  监控平台忽然告警 GC overhead limit exceeded 这个异常 第一反应估计是堆溢出了.于是各种各种jmap  jstack下载堆栈文件和堆日志文件. 以下是 ...

  4. JVM 报 GC Overhead limit exceeded 是什么意思?

    默认情况下,并不是等堆内存耗尽,才会报 OutOfMemoryError,而是如果 JVM 觉得 GC 效率不高,也会报这个错误. 那么怎么评价 GC 效率不高呢?来看下源码: 呢?来看下源码gcOv ...

  5. GC overhead limit exceeded,tomcat修改jvm内存

    tomcat修改jvm内存 内存大小:-Xms256M -Xmx512M -XX:PermSize=256m -XX:MaxNewSize=256m -XX:MaxPermSize=512m -Dja ...

  6. spark异常篇-OutOfMemory:GC overhead limit exceeded

    执行如下代码时报错 # encoding:utf-8 from pyspark import SparkConf, SparkContext from pyspark.sql import Spark ...

  7. eclipse:Tomcat设置jvm,解决java.lang.OutOfMemoryError: Java heap space 堆内存溢出

    eclipse 有启动参数里设置jvm大小,因为eclipse运行时自己也需要jvm,所以eclipse.ini里设置的jvm大小不是具体某个程序运行时所用jvm的大小,这和具体程序运行的jvm大小无 ...

  8. JVM内存溢出分析java.lang.OutOfMemoryError: Java heap space

    JVM内存溢出查询java.lang.OutOfMemoryError: Java heap space查出具体原因分为几个预备步骤 1.在运行java程序是必须设置jvm -XX:+HeapDump ...

  9. java heap space解决方法和JVM参数设置

    在JVM中如果98%的时间是用于GC(Garbage Collection)且可用的 Heap size 不足2%的时候将抛出异常信息,java.lang.OutOfMemoryError: Java ...

随机推荐

  1. POJ3277 线段树段更新,点询问+二分离散化+暴力

    题意:       x轴上有一些矩形,问你这些矩形覆盖的面积和是多少. 思路:       首先范围很大,n很小,果断离散化,然后我们就是求出任意区间的最大值作为当前区间的高,最后在算一遍答案就行了, ...

  2. Shiro反序列化漏洞复现

    Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码和会话管理.使用Shiro的易于理解的API,可以快速.轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企 ...

  3. 简化mapstruct代码: mapstruct-spring-plus

    mapstruct MapStruct 是一个属性映射工具,只需要定义一个 Mapper 接口,MapStruct 就会自动实现这个映射接口,避免了复杂繁琐的映射实现.MapStruct官网地址: h ...

  4. 0803-PyTorch的Debug指南

    0803-PyTorch的Debug指南 目录 一.ipdb 介绍 二.ipdb 的使用 三.在 PyTorch 中 Debug 四. 通过PyTorch实现项目中容易遇到的问题 五.第八章总结 py ...

  5. android手势识别

    一.简单手势识别: 简单手势识别分为以下几个步骤: 1.手指触碰屏幕时,触发MotionEvent事件: 2.该事件被OnTouchListener监听,可在它的onTouch()方法中获得该Moti ...

  6. Yii2表头强制不换行

    在Yii2中使用GridView生成的表格有一个小问题,那就是表头的列宽是根据列的值自适应的,但有时值的长度比较小,表头就会出现下面这种情况(表头不在同一行,非常的不利于数据的查看) 设置强制不换行可 ...

  7. 2-9-9-12分页机制(xp)

    10-10-12分页限制 10-10-12分页因为页表PEB只有四个字节所以只能访问2^32 = 4GB物理地址空间,现在的物理内存都大于4GB为了能访问到更多的物理内存2-9-9-12将PEB的大小 ...

  8. java面试一日一题:java中一个对象实例的结构是什么样子的

    问题:请讲下在java程序运行时一个对象实例的数据结构是什么样子的 分析:该问题主要考察对java中对象的理解,在程序运行过程中一个对象实例是以什么样的形式存在的 回答要点: 主要从以下几点去考虑, ...

  9. 分布式日志传输系统Databus(一)--系统介绍

    Databus系统是微博DIP团队开源的分布式日志传输系统.它是一个分布式.高可用的,用于采集和移动大量日志数据的服务.它基于流式数据的简单而灵活的架构,具备健壮性和容错性,具有故障转移与恢复机制.它 ...

  10. Docker网络,手把手教你如何实现容器网络相关知识

    Docker网络 理解Docker0 清空所有环境 测试 三个网络 #问题:docker 是如何处理容器网络访问的? [root@hsStudy /]# docker run -d -P --name ...