自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

面試官:說一下Java的共享內(nèi)存模型

開發(fā) 前端
架構(gòu)

前言

目前正在出一個Java多線程專題長期系列教程,從入門到進階含源碼解讀, 篇幅會較多, 喜歡的話,給個關(guān)注?? ~ 本篇內(nèi)容篇純理論一點

并發(fā)編程模型

我們之前給大家講了多線程的一些知識,首先我們要知道的是在并發(fā)編程模型下會產(chǎn)生兩大問題

  • 線程之間如何通信
  • 線程之間如何同步

解決這兩個問題主要有兩種并發(fā)模型:

  • 消息傳遞模型
  • 共享內(nèi)存模型

那么它們是如何解決的呢?

消息傳遞模型

如何通信 ?

線程之間沒有公共狀態(tài),必須通過發(fā)消息來顯式通信

如何同步 ?

發(fā)消息本身就是同步的,因此它是隱式的

共享內(nèi)存模型

如何通信 ?

線程之間共享程序的公共狀態(tài),通過讀寫內(nèi)存中的公共狀態(tài)來進行隱式通信

如何同步 ?

需要顯示指定線程之間互斥執(zhí)行

在Java中使用的是第二種,共享內(nèi)存并發(fā)模型的方式

Java內(nèi)存模型結(jié)構(gòu)

首先說一下運行時數(shù)據(jù)區(qū),主要分為兩類

  • 線程共享區(qū),主要包含方法區(qū)和堆
  • 線程私有區(qū),主要包含 虛擬機棧,本地方法棧,程序計數(shù)器

對于每一個線程來說,棧都是私有的,堆是共享的,所以棧中的變量,比如局部變量,方法定義參數(shù)、異常處理器參數(shù),它們都不是共有的,所以內(nèi)存之間是不可見的,所以也不收內(nèi)存模型影響,而堆中的變量時共享的,所以又叫共享變量, 內(nèi)存可見性是針對共享變量

堆中一定就可見性嗎

堆中也會出現(xiàn)內(nèi)存不可見的問題,怎么產(chǎn)生的呢?這是因為現(xiàn)代計算機為了高效,往往會在高速緩存區(qū)中緩存共享變量,因為cpu訪問緩存區(qū)比訪問內(nèi)存要快得多。

所謂內(nèi)存不可見性,就是線程對某個共享變量在線程自己的緩沖中存在副本的時候?qū)χ鲀?nèi)存中共享變量的值是不可見的,看不見主存中的值。線程操作一個共享變量時,它首先從主存中拉取并復(fù)制一份變量放置到自己的工作內(nèi)存中,然后在工作內(nèi)存中對變量進行修改,處理完之后將工作內(nèi)存中的值重新寫回到主存中。所以在這個過程中,如果在緩存失效之前立即命中,就會導(dǎo)致更新過的主存中值不一致的問題

在Java中,每個線程都有自己的本地內(nèi)存,存儲了該線程以讀、寫共享變量的副本,它是一個抽象的概念,線程之間的通信有內(nèi)存模型控制,簡稱JMM

  • 所有的共享變量都存在主內(nèi)存中。
  • 每個線程都保存了一份該線程使用到的共享變量的副本。

所以「線程間通信必須經(jīng)過主內(nèi)存」,JMM規(guī)定,「線程對共享變量的所有操作都必須在自己的本地內(nèi)存中進行,不能直接從主內(nèi)存中讀取」。

Java中的volatile關(guān)鍵字可以保證多線程操作共享變量的可見性以及禁止指令重排序,synchronized關(guān)鍵字不僅保證可見性,同時也保證了原子性(互斥性)。在更底層,JMM通過內(nèi)存屏障來實現(xiàn)內(nèi)存的可見性以及禁止重排序。為了程序員的方便理解,提出了happens-before,它更加的簡單易懂,從而避免了程序員為了理解內(nèi)存可見性而去學(xué)習(xí)復(fù)雜的重排序規(guī)則以及這些規(guī)則的具體實現(xiàn)方法。

結(jié)束語

本節(jié)內(nèi)容可能不像之前那么好理解,比較抽象,所以本文也有不足的地方,大家自己可以多查查一些資料,綜合理解。?

責(zé)任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2023-09-12 14:56:13

MyBatis緩存機制

2021-07-28 10:08:19

類加載代碼塊面試

2025-03-10 07:05:07

2022-06-06 15:33:20

線程Java釋放鎖

2023-02-18 13:34:14

Nacos健康檢查機制

2024-02-21 16:42:00

2020-07-30 07:58:36

加密算法

2024-02-27 15:23:48

RedLock算法Redis

2023-02-08 08:32:41

輪詢鎖

2023-12-29 13:45:00

2024-01-29 10:08:11

零拷貝Zero-copyCPU 拷貝

2021-06-02 11:25:18

線程池Java代碼

2023-01-30 15:39:40

GETHTTP

2023-11-29 08:00:53

JavaTreeMap底層

2021-11-27 08:13:13

Final 面試

2024-02-22 15:36:23

Java內(nèi)存模型線程

2020-08-07 15:15:01

Java內(nèi)存泄漏面試

2021-04-19 18:56:58

大數(shù)字符串運算

2023-02-07 06:47:58

JVM 模塊Java 虛擬機

2021-11-08 15:59:01

MyBatis關(guān)聯(lián)開發(fā)
點贊
收藏

51CTO技術(shù)棧公眾號