JVM内存设置,各个参数含义和设置后不起作用问题

这两天才来公司,遇到很棘手的问题,把公司项目下载下来后无法运行,报错内存溢出问题,然后网上一大堆问题的答案,按照网上的答案解决了tomcat:java.lang.OutOfMemoryError: PermGen space问题,但是后面还有tomcat:java.lang.OutOfMemoryError: Java heap space问题。按照网上的说法设置并没有解决我的问题,于是开始太多JVM内存机制。在这里终结一下怎样解决的问题,希望能帮助自己和他人。如有错误,请大佬指出。

首先来看一下JVM内存有哪些区域,主要的作用是什么?(摘自http://blog.csdn.net/zhoudaxia/article/details/26454421/)

运行时数据区(Runtime Data Areas)


图 4: 运行时数据区

  运行时数据区是在JVM运行的时候操作系统所分配的内存区。运行时内存区可以划分为6个区域。在这6个区域中,一个PC Register,JVM stack 以及Native Method Statck都是按照线程创建的,Heap,Method Area以及Runtime Constant Pool都是被所有线程公用的。

  •  PC寄存器(PC register):每个线程启动的时候,都会创建一个PC(Program Counter,程序计数器)寄
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JVM(Java Virtual Machine)的内存结构可以分为以下几个部分: 1. 程序计数器(Program Counter Register):程序计数器是一块较小的内存空间,它可以看作是当前线程所执行的字节码的行号指示器,也可以理解为每个线程都有一个独立的程序计数器,它记录了当前线程所执行的字节码的行号。 2. Java虚拟机栈(Java Virtual Machine Stacks):每个线程在创建时都会创建一个虚拟机栈,用于存储局部变量、方法参数、返回值以及部分计算结果等。虚拟机栈的大小可以通过-Xss参数进行设置。 3. 本地方法栈(Native Method Stack):本地方法栈与Java虚拟机栈的作用类似,不同的是本地方法栈为虚拟机执行Native方法服务。 4. Java堆(Java Heap):Java堆是Java虚拟机管理的内存中最大的一块。所有线程共享Java堆,用于存储创建的对象实例。Java堆的大小可以通过-Xmx和-Xms参数进行设置。 5. 方法区(Method Area):方法区也是所有线程共享的内存区域,用于存储类信息、常量、静态变量、即时编译器编译后的代码等数据。方法区的大小可以通过-XX:MaxPermSize参数进行设置。 6. 运行时常量池(Runtime Constant Pool):运行时常量池是方法区的一部分,用于存储编译时期生成的各种字面量和符号引用,以及运行时期生成的一些常量。 7. 直接内存(Direct Memory):直接内存并不是JVM运行时数据区的一部分,它是操作系统提供的一块直接内存区域。JVM可以通过DirectByteBuffer来操作直接内存,直接内存的大小可以通过-XX:MaxDirectMemorySize参数进行设置

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值