4.JVM内存模型

1.stack(线程私有)

管理方法执行时的内存模型。stack里面有帧,用于记录方法执行时的变量,参数,动态链接库,返回信息,地址等。

递归调用时要非常注意stack over flow的异常。

还受当前内存的限制,如果内存不够也会oom异常。

2.native method area(线程私有)

不是java实现而是通过本地的C/C++实现,此时jvm引擎要通过JNI去做。

3.heap(全局共有) 

用于存储对象。也是jvm垃圾回收的主要区域。 

4.c/c++(全局共有)

5.program counter register(线程私有)

每个线程私有的记录程序下条运行指令的对象,主要用于线程数大于core时起作用。可以指向java,也可以是c、c++,但此时为null

6.method area包含constant pool(全局共有)

存放常量,静态变量,编译后的字节码,一般情况下不会被jvm回收。但是当类所创建的所有实例被回收时,同时在这个类的classold也被回收时,这时有可能方法区的代码有可能被回收。

5.direct memory

使用nio时直接通过本地来分配具体的内存空间。tachyon大规模的使用nio。

虽然直接使用channel和buffer的方式作为新的内存方式,但仍然可能会导致内存溢出。此时会产生offheap级别的异常。




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值