「每日五分钟,玩转JVM」:运行时数据区域概要

概述

咱们首先来认识一下JVM的运行时数据区域,若是说JVM是一我的,那么运行时数据区域就是这我的的骨架,它支撑着JVM的运行,因此咱们先来学习一下运行时数据区域的分类和简单介绍。多线程

分类

从所在区域角度上来讲,能够分为内部内存和外部内存,其中内部的内存又包括了线程独占区和线程共享区。学习

在JVM内部,从线程共享角度上来讲,又能够分为线程独占区和线程共享区。线程

线程独享区能够中包含如下三种数据区域:3d

  • 程序计数器(Program Counter Register)code

  • 虚拟机栈(VM Stack)cdn

  • 本地方法栈(Native Method Stack)对象

线程共享区中包含如下两种数据区域:blog

  • 方法区(Method Area)
  • 堆(Heap)

在JVM外部也就是本地内存中,包含了直接内存元数据(Metadata),在JDK 1.8中,元数据就是咱们以前的永久代(持久代)内存

他们之间的区别是,JDK 7在持久代中的常量池在JDK 8移到了堆内存中,剩余部分移到了元数据中。虚拟机

多线程的实现原理

上面咱们把运行时的数据区域分为了线程独占区和线程共享区,那么Java中的多线程是怎么实现的呢?这能够帮助咱们对于线程独占区和共享区有更深的理解。

在多个线程运行的时候,实际上是把CPU的使用时间分割成了无数个小份,而后根据优先级去给这些线程分配时间,CPU在这些小时间块中快速切换,给用户的感觉就是多线程同时在运行,以下图:

经过这个图,咱们能够清晰的看出是如何达到多线程的效果(其实在通讯的时候也有一样的原理——时分多路复用)

其实通俗一点来讲,线程的独占区主要是为了控制方法的正常运行,而线程的共享区更相似于一个存储信息的仓库

打个简单的比方,如今有一个方法,咱们使用两个线程同时去调用这个方法,属于该方法的信息就能够称之为独占区,而类中的变量,对象却能够被两个方法同时使用

两种异常

在和JVM打交道的过程当中,咱们常常会遇到两种错误:StackOverflowErrorOutOfMemoryError

StackOverflowError异常出如今线程独占区的本地方法栈和虚拟机栈中,而OutOfMemoryError会出如今除程序计数器外的全部区域。

公众号

原创文章,才疏学浅,若有不对之处,万望告知!

相关文章
相关标签/搜索