导语
在JVM中除了有堆内存参数配置以外,还有一些其他内存例如方法区、线程栈直接内存等等。他们与堆内存来说是相对比较独立的内存空间。与堆内存相比较这些内存与应用程序本身的关系不大,但是如果将其放到整个的系统层面上来说的话在有效的配置之后会使得系统的稳定性和性能有一定程度上的提升。
文章目录
方法区的配置参数
与Java堆类似,方法区也是所有线程共享的一块区域,用于保存系统类的信息,例如字段、方法、常量池等等。方法区的大小决定了系统可以保存多少个类,如果系统在定义了太多的方法就会导致整个的方法区溢出,同样虚拟机也会抛出内存溢出的异常。
在JDK1.6、JDK1.7中,方法去可以理解为永久代Perm,永久区可以使用下面介绍的参数来进行配置,在默认的情况下最大值设为64MB。在一定程度上,一个大的永久区可以存放跟多的类信息,但是如果系统使用了一些动态代理,那么可能会在运行时生成大量的类,如果这样就可以根据实际情况来合理的设置方法区的大小,从而保证了不会出现方法区内存溢出。
首先要知道方法区主要存放一些元信息,在JDK1.6和JDK1.7的版本中可以使用如下的两个参数来设置永久区大小
-XX:PermSize 表示初始化永久区大小
-XX:MaxPermSize 表示最大永久区大小
在JDK1.8中彻底的移除了永久区,使用了新的元数据区存放类的元数据,默认的情况下元数据区只受到系统可用内存的限制,但是还是可以使用如下的参数进行设置
-XX:MaxMetaspceSize 指定元数据区域最大的大小。
小例子
这里给出的小例子只是为了测试来使用不需要关心起具体的实现逻辑是什么?由于这里使用到了cglib,所以笔者使用的是IDEA工具进行调试。
本文介绍了JVM方法区的配置参数,重点讲解了JDK1.8中Metaspace的参数配置,包括-XX:MetaspaceSize和-XX:MaxMetaspaceSize等。通过小例子展示了Metaspace内存溢出的情况,并分析了Metaspace大小不受限制的原因。文章还探讨了Compressed Class Space的影响以及如何通过设置参数解决内存溢出问题。
订阅专栏 解锁全文
1323

被折叠的 条评论
为什么被折叠?



