对Java的内存分配的简单了解(1)

在JVM内部,Java内存模型把内存分成了两部分:线程栈区和堆区,一般来讲,可以更加细致的分为五个部分:
Method Area,Heap,VM Stack,Native Method Stack,Progrom Counter Register。
这其中Method Area和Heap属于允许多个线程共享的部分,而VM Stack,Native Method Stack,Progrom Counter Register则不允许线程共享。
先看不允许线程共享的部分。
在Java内存模型中,线程栈区储存的是当前执行的方法所调用的信息,包括该方法本地变量的内容。每个线程都有独立的线程栈,同时每个线程也只能读取自己的线程栈。每个线程私有的栈,生命周期和该线程是一致的。
JMM定义了线程和主内存之间的抽象关系:线程之间的共享变量存储在主内存(main memory)中,每个线程都有一个私有的本地内存(local memory),本地内存中存储了该线程以读/写共享变量的副本。
当线程相互之间进行通讯时,实质上是在主内存上交换变量的副本。例如,当线程1向线程2发送一个消息时,线程1先在本地内存上生成一个要发送的变量的副本,然后主内存会从线程1的本地内存中接受这个副本,并把这个副本传给线程2的本地内存,线程2从自己的本地内存中接收这个副本,就完成了一次线程中的通信。当然,这只是一个基础的例子,关于线程之间的通信和变量的共享,以后会有更详细的说明。
线程的栈区中,可以储存原始数据类型,例如int,double,boolean型等,也可以存储对象的引用,但是对象实例的具体属性等信息则保存在Heap中。
我在这里简单的把VM Stack和Native Method Stack都理解为线程栈区。而剩下的程序计数器是一块较小的内存区域,作用可以看做是当前线程执行的字节码的位置指示器。分支、循环、跳转、异常处理和线程恢复等基础功能都需要依赖这个计算器来完成。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值