美文网首页文字欲
Java并发那些事儿序言

Java并发那些事儿序言

作者: 绍圣 | 来源:发表于2019-06-18 17:00 被阅读0次

JVM执行的Java代码是被转换成由字节码组成的class文件。那么JVM是如何在字节码层面上执行线程同步的?

回顾JVM内存结构

JVM在支持多线程上,其实就是在协调多个线程对共享数据的访问。JVM的内存结构主要包含:栈,堆,方法区等。

在JVM中,每个线程独享一块栈内存,其中包括局部变量,线程调用的每个方法的参数和返回值。其他线程无法读取到该栈内存中的数据。栈中的数据仅限于基本类型和对象引用。所以,栈上是无法保存真实的对象的,只能保存对象的引用。真正的对象保存在堆中。

在JVM中,堆内存是所有线程共享的。堆中只包含对象,没有其他东西。所以堆上无法保存基本类型和对象引用。堆和栈分工明确。(说明数组是保存在堆上,即使是基本类型的数据也是保存在堆中,在java中数组就是对象)

在JVM中,类的静态变量是保存在方法区中,方法区和栈类似,只包含基本类型和对象引用。和栈不同的是,方法区中的静态变量可以被所有线程访问。

对象和类的锁

JVM中有两块内存区域可以被所有线程共享:堆上的所有对象;方法区上的静态变量。

那么多个线程方法同一个对象或是静态变量,就会出现竞争,出现同步问题。为了协调多个线程之间的共享数据访问,虚拟机给每个对象和类都分配了一个锁,在同一时刻,只有一个线程可以拥有这个类或是对象。如果一个线程想要获得某个类或者对象的锁,需要询问虚拟机。当一个线程向虚拟机申请某个类或者对象的锁之后,线程会进入等待这个类或者对象的锁的池,并且阻塞起来。等待虚拟机在时机到了后把锁给线程。当线程使用完锁之后,它再把锁还给虚拟机。

类锁是通过锁对象实现的,当虚拟机加载一个类的时候,会为此类实例化一个java.lang.Class对象,当锁住一个类的时候,其实锁住的是其对应的Class对象。(一个类在整个虚拟机中只有一个Class对象)。

Monitors

monitors主要功能是监控一段代码,确保在同一个时间只有一个线程在执行。每个monitor都与一个对象相关联。当线程执行到监视器监视下的代码块中的第一条指令时,线程必须获取对被引用对象的锁定。在线程获取锁之前,是无法执行这段代码的,一旦获得锁,线程便可以进入被保护的代码开始执行。

当线程离开代码块时,无论如何离开,都会释放所关联对象的锁。

多次加锁

同一个线程可以对同一个对象进行多次加锁。每个对象维护着一个记录着被锁次数的计数器。未被锁定的对象的该计数器为0,当一个线程获得锁后,该计数器自增变为1,当同一个线程再次获得该对象的锁的时候,计数器再次自增。当同一个线程释放锁的时候,计数器再自减。当计数器为0的时候,锁将被释放,其他线程便可以获得锁。

参考:

[译]Java虚拟机是如何执行线程同步的-HollisChuang's Blog

How the Java virtual machine performs thread synchronization | JavaWorld

相关文章

  • Java并发那些事儿序言

    JVM执行的Java代码是被转换成由字节码组成的class文件。那么JVM是如何在字节码层面上执行线程同步的? 回...

  • Java并发那些事儿-CAS

    CAS(Compare And Swap)比较与交换:一种无锁算法。在不使用锁(没有线程被阻塞)的情况下实现多线程...

  • Java并发那些事儿-锁

    公平锁和非公平锁 公平锁是指多个线程按照申请锁的顺序来获取锁,线程直接进入队列中排队,队列中的第一个线程才能获得锁...

  • Java并发那些事儿-Moniter

    在多线程访问共享资源的时候,经常会带来可见性和原子性的安全问题。为了解决这类线程安全的问题,Java提供了同步机制...

  • Java并发那些事儿-Synchronized

    作为一个Java开发,在有多线程竞争同一个资源的时候,为了达到原子性。首先想到的解决方案就是使用synchroni...

  • Java并发那些事儿-对象头

    对象头信息是与对象自身定义的数据无关的额外存储成本,在对象头中有一些运行时数据,其中就包括和多线程相关的锁的信息(...

  • Java并发那些事儿-对象模型

    Java的对象模型 oop-klass model 在JVM的内存结构中,对象是保存在堆内存中,对对象的操作其实是...

  • Java并发那些事儿-优化锁

    乐观锁和悲观锁 对于同一个数据的并发操作,悲观锁认为在使用数据的时候一定会有别的线程来修改数据,因此在获取数据的时...

  • Java并发和多线程那些事儿

    我记得我接触电脑的时候是在小学三年级的时候,那是1995年,那年发布了windows95,但是我学习的时候还是只是...

  • Java并发教程

    Java并发教程 Java并发概述Java并发环境设置Java并发主要操作Java并发性线程间通信Java并发同步...

网友评论

    本文标题:Java并发那些事儿序言

    本文链接:https://www.haomeiwen.com/subject/nhzffctx.html