前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >理论:第九章:JVM内存模型,算法,垃圾回收器,调优,四大引用,常见的JVM错误,类加载机制(双亲委派),创建一个对象,这个对象在内存中是怎么分配的?

理论:第九章:JVM内存模型,算法,垃圾回收器,调优,四大引用,常见的JVM错误,类加载机制(双亲委派),创建一个对象,这个对象在内存中是怎么分配的?

作者头像
Java廖志伟
发布2022-09-28 17:12:59
8040
发布2022-09-28 17:12:59
举报
文章被收录于专栏:高级开发进阶

前三个已经烂大街了,我这里就不写了,点击蓝色字体查看相关的博文

JVM内存模型

JVM算法

JVM垃圾回收器

JVM调优

查看参数

第一种:

查看进程编号:jps -l

jinfo -flag 具体参数 java进程编号

jinfo -flags 具体参数

第二种:

查看JVM出厂默认设置:java -XX:+PrintFlagsInitial

查看JVM修改更新的内容:java -XX:+PrintFlagsFinal -version

查看默认垃圾回收器:java -XX:+PrintCommandLineFlags -version

常用参数:

-Xmx(-XX:MaxHeapSize):初始大小内存:初始化的值是物理内存的四分之一

-Xms(-XX:InitialHeapSize):最大分配内存:初始化的值是物理内存的六十四分之一

-Xss(-XX:ThreadStackSize):设置单个线程栈的大小,一般默认为512k~1024k

-Xmn:设置年轻代的大小

-XX:MetaspaceSize:设置元空间大小 元空间的本质和永久代类似,都是对JVM规范中方法区的实现。不过元空间与永久代之间的区别在于:元空间不在虚拟机中,而是在本地内存中,默认情况下,元空间的大小仅受本地内存限制。

-Xms 128m -Xmx4096m -Xss1024k -XX:MetaspaceSize=512m -XX:+PrintCommandLineFlags -XX:+PrintGCDetails -XX:+UseSerialGC

-Xms 128m:初始内存128M

-Xmx4096m :最大堆内存4G

-Xss1024k:初始栈大小1024K

-XX:MetaspaceSize=512m:元空间512M

-XX:+PrintCommandLineFlags:打印默认参数

-XX:+PrintGCDetails :打印GC回收的细节

-XX:+UseSerialGC:串行垃圾回收器

-XX:+PrintGCDetails命令打印的:

案例:https://blog.csdn.net/java_wxid/article/details/103021907

-XX:SurvivorRatio:设置新生代中eden和S0/S1空间的比例。

默认:-XX:SurvivorRatio=8,Eden:S0:S1=8:1:1;

假如-XX:SurvivorRatio=4,Eden:S0:S1=4:1:1。SurvivorRatio的值就是设置eden去的比例占多少,S0和S1相同

-XX:NewRatio:配置年轻带与老年带在堆结构的占比。

默认:-XX:NewRatio=2新生代占1,老年代2,年轻带占整个堆的1/3。假如:-XX:NewRatio=4新生代占1,老年代占4,年轻带占整个堆的1/5。NewRatio的值就是设置老年代的占比,剩下的1给新生代。

-XX:MaxTenuringThreshold:设置垃圾的最大年龄

java8之后这个值最大只能设置为15,最低是0

落地实现:

拖地实现的案例:

四大引用

强引用Reference(默认支持模式)

例如:Book book = new Book();

理论:

实战:

软引用SoftReference

理论:

实战:

内存足够时:

 内存不够时:

弱引用WeakReference

理论:

实战:

软引用和弱引用的应用场景:

 实战:WeakHashMap的使用

虚引用PhantomReference

理论:

实战:

弱引用与引用队列

虚引用与引用队列:

常见的JVM异常

StackOverflowError:线程栈空间被耗尽,没有足够资源分配给新创建的栈帧

OutofMemoryError:Java heap space 堆内存中的空间不足以存放新创建的对象

OutOfMemoryError: GC overhead limit exceeded 超过98%的时间用来做GC并且回收了不到2%的堆内存

OutOfMemoryError: Direct buffer memory 堆外内存

OutofMemoryError:unable to create new native thread

解决方案:

OutOfMemoryError: Metaspace 元数据区(Metaspace) 已被用满

解决方案:-XX:MaxMetaspaceSize=512m

类加载机制(双亲委派)

启动类加载器(Bootstrap)C++ 扩展类加载器(Extension)Java 应用程序类加载器(AppClassLoader)Java

双亲委派模型工作原理:如果一个类加载器收到类加载的请求,它首先不会自己去尝试加载这个类,而是把这个请 求委派给父类加载器完成。每个类加载器都是如此,只有当父加载器在自己的搜索范围内找不到指定的类时(即 ClassNotFoundException),子加载器才会尝试自己去加载。

创建一个对象,这个对象在内存中是怎么分配的?

https://www.zhihu.com/question/55237879/answer/1275043584

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-04-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • JVM调优
    • 查看参数
      • 常用参数:
        • 四大引用
          • 常见的JVM异常
            • 类加载机制(双亲委派)
              • 创建一个对象,这个对象在内存中是怎么分配的?
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档