jvm学习(一)内存模型及自动内存管理机制

内存模型
1.7版本:Java进程 ,本地内存,Java进程包括:线程,堆, 方法区,本地内存中包括直接内存,其中线程中包括程序计数器,jvm虚拟机栈,本地方法栈,方法区中包括,类常量池和运行时常量池,堆中包括字符串常量池。
1.8版本:与1.7版本相比,本地内存中增加了一个元数据区,元数据区就是1.7版本中的方法区。Java进程中只有线程和堆,其中堆中有字符串常量池。
程序计数器:当前线程所执行字节码的行号指示器
其中,程序计数器,jvm虚拟机栈,本地方法栈都是线程私有。
原因:虚拟机的多线程是由线程间的轮流切换并配置一定的执行时间来实现的。在确定的时刻,处理器只会执行一个线程中的指令,为了切换后能回到正确的位置,每个线程中只能有一个独立的程序计数器
JVM虚拟机栈:每一个方法在执行的时候会创建一个栈帧,用于储存局部变量表,操作数,动态链接,方法出口,每一个方法的调用到执行完成的过程对应了每一个栈帧在虚拟机栈从入栈到出栈的过程。
StackOverflowError和OutofMemoryError
本地方法栈:执行的是native方法, OutofMemoryError
堆:存放实例对象以及进行垃圾回收的 主要区域,堆中没有完成实例分配,并且不能再扩展就会
方法区:储存已被虚拟机类加载的类信息,常量,静态变量等
运行时常量池:class文件中除了类的版本,字段,方法,接口等描述信息外,还有常量池(用于存放编译期生成的各种字面量和符号引用)对于运行时常量池,虚拟机没有任何格式上的要求。
直接内存:不是虚拟机运行时数据区的一部分,NIO类基于通道和缓冲区建立的,可以使用Nativ函数库直接分配堆外内存,然后通过存放在堆中的一个对象进行引用操作。提高了效率,避免在Java堆和native堆中的来回复制数据
自动内存管理机制

在自动内存管理机制的帮助下,Java程序员不需要对每个创建的对象进行free,不容易出现内存溢出的问题。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值