java创建一个内存10M的对象_JVM之内存和对象创建过程

1.5.3多核并行

Lambda支持会极大改善目前Java语言不适合函数式编程的现状.函数式编程的一个重要优点就是天然适合并行运行.

5644fc922270a0bd469de00ac94d8178.png

2.2.1程序计数器(每条线程独立私有)

程序计数器是一块较小的内存空间,它可以看做是当前线程所执行的字节码的行号指示器

字节码解释器工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令,分支 循环 跳转 异常处理 线程恢复等基础功能都需要依赖这个计数器来完成

jvm的多线程是通过线程轮流切换并分配处理器执行时间的方式来实现

2.2.2 Java虚拟机栈(JVM stacks)

stacks也是线程私有 描述的是java方法执行的内存模型,每个方法在执行的同时会创建一个栈帧(Stack Frame)用于存储局部变量表,操作数栈,动态链接,方法出口等信息。

每一个方法从调用到执行完成的过程,就对应栈帧从入栈到出栈的过程

在概念模型中,两个栈帧作为虚拟机栈的元素,相互之间是完全独立的,但是大多数虚拟机的实现里都会作一些优化处理,令两个栈帧出现一部分重叠。让下栈帧的部分操作数栈与上面栈帧的部分局部变量表重叠在一起,这样在进行方法调用返回时就可以共用一部分数据,而无须进行额外的参数复制传递了,重叠过程如下图:

7c304b8bc9576b268c60406c5ac2d88b.png

局部变量表存放八种基本数据类型、对象引用(reference类型,不一定是本身 也可能是指向对象地址的指针或者句柄)、returnAddress(指向字节码指令的地址)

(64位的long和double会占用两个局部变量空间(Slot)(字宽),其他为1个)

局部变量表的内存空间在编译期间完成分配(执行时不会改变空间大小)

stackOverflowError:线程请求的栈深度大于虚拟机所允许的深度

OutOfMemoryError:虚拟机栈动态拓展时无法申请到足够的内存

2.2.3本地方法栈(为JVM使用到的Native方法服务)

和虚拟机栈类似 区别是本地方法栈执行Native方法服务

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值