JMM和底层实现原理

Posted lys-lyy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JMM和底层实现原理相关的知识,希望对你有一定的参考价值。

一、并发编程领域的关键问题

1.线程之间的通信和同步

1.1  线程之间的通信

线程的通信是指线程之间以何种机制来交换信息。在编程中,线程之间的通信机制有两种,共享内存消息传递

1.1.1  共享内存  在共享内存的并发模型里,线程之间共享程序的公共状态,线程之间通过写-读内存中的公共状态来隐式进行通信,典型的共享内存通信方式就是通过共享对象进行通信

1.1.2 消息传递  在消息传递的并发模型里,线程之间没有公共状态,线程之间必须通过明确的发送消息来显式进行通信,在java中典型的消息传递方式就是wait()和notify()。

1.2  线程之间的同步

同步是指程序用于控制不同线程之间操作发生相对顺序的机制。 在共享内存并发模型里,同步是显式进行的程序员必须显式指定某个方法或某段代码需要在线程之间互斥执行。 在消息传递的并发模型里,由于消息的发送必须在消息的接收之前,因此同步是隐式进行的

结论:Java的并发采用的是共享内存模型

以上是关于JMM和底层实现原理的主要内容,如果未能解决你的问题,请参考以下文章

JMM和底层实现原理

JMM和Volatile底层原理分析

JMM及volatile深入理解

多线程的实现原理

JMM及volatile深入理解

CAS技术实现之底层原理