摘要:內(nèi)存模型基本概念計(jì)算機(jī)在執(zhí)行程序時,每條指令都是在中執(zhí)行的,而執(zhí)行指令過程中,勢必涉及到數(shù)據(jù)的讀取和寫入。有序性即程序執(zhí)行的順序按照代碼的先后順序執(zhí)行。
內(nèi)存模型基本概念
計(jì)算機(jī)在執(zhí)行程序時,每條指令都是在CPU中執(zhí)行的,而執(zhí)行指令過程中,勢必涉及到數(shù)據(jù)的讀取和寫入。由于程序運(yùn)行過程中的臨時數(shù)據(jù)是存放在主存(物理內(nèi)存)當(dāng)中的,這時就存在一個問題,由于CPU執(zhí)行速度很快,而從內(nèi)存讀取數(shù)據(jù)和向內(nèi)存寫入數(shù)據(jù)的過程跟CPU執(zhí)行指令的速度比起來要慢的多,因此如果任何時候?qū)?shù)據(jù)的操作都要通過和內(nèi)存的交互來進(jìn)行,會大大降低指令執(zhí)行的速度。因此在CPU里面就有了高速緩存。
并發(fā)編程中的三個概念1?原子性
即一個操作或者多個操作,要么全部執(zhí)行并且執(zhí)行的過程不會被任何因素打斷,要么就都不執(zhí)行。
2?可見性
指當(dāng)多個線程訪問同一個變量時,一個線程修改了這個變量的值,其他線程能夠立即看得到修改的值。
3?有序性
即程序執(zhí)行的順序按照代碼的先后順序執(zhí)行。一般來說,處理器為了提高程序運(yùn)行效率,可能會對輸入代碼進(jìn)行優(yōu)化,它不保證程序中各個語句的執(zhí)行先后順序同代碼中的順序一致,但是它會保證程序最終執(zhí)行結(jié)果和代碼順序執(zhí)行的結(jié)果是一致的。
在Java虛擬機(jī)規(guī)范中試圖定義一種Java內(nèi)存模型(Java Memory Model,JMM)來屏蔽各個硬件平臺和操作系統(tǒng)的內(nèi)存訪問差異,以實(shí)現(xiàn)讓Java程序在各種平臺下都能達(dá)到一致的內(nèi)存訪問效果。那么Java內(nèi)存模型規(guī)定了哪些東西呢,它定義了程序中變量的訪問規(guī)則,往大一點(diǎn)說是定義了程序執(zhí)行的次序。注意,為了獲得較好的執(zhí)行性能,Java內(nèi)存模型并沒有限制執(zhí)行引擎使用處理器的寄存器或者高速緩存來提升指令執(zhí)行速度,也沒有限制編譯器對指令進(jìn)行重排序。也就是說,在java內(nèi)存模型中,也會存在緩存一致性問題和指令重排序的問題。
注意,圖中的工作內(nèi)存實(shí)際上就對應(yīng)于硬件層面上的cpu cache。
volatile關(guān)鍵字它保證了可見性和有序性,但是它不保證原子性。
下面這段話摘自《深入理解Java虛擬機(jī)》:
“觀察加入volatile關(guān)鍵字和沒有加入volatile關(guān)鍵字時所生成的匯編代碼發(fā)現(xiàn),加入volatile關(guān)鍵字時,會多出一個lock前綴指令”
lock前綴指令實(shí)際上相當(dāng)于一個內(nèi)存屏障(也成內(nèi)存柵欄),內(nèi)存屏障會提供3個功能:
它確保指令重排序時不會把其后面的指令排到內(nèi)存屏障之前的位置,也不會把前面的指令排到內(nèi)存屏障的后面;即在執(zhí)行到內(nèi)存屏障這句指令時,在它前面的操作已經(jīng)全部完成;
它會強(qiáng)制將對緩存的修改操作立即寫入主存;
如果是寫操作,它會導(dǎo)致其他CPU中對應(yīng)的緩存行無效。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/67011.html
摘要:比如用修飾的變量,就會確保變量在修改時,其它線程是可見的。。多核環(huán)境中,多個線程分別在不同的中運(yùn)行,就意味著,多個線程都有可能將變量拷貝到當(dāng)前運(yùn)行的里。當(dāng)線程讀取變量時,它將能看見被線程寫入的東西。 volatile是用來標(biāo)記一個JAVA變量存儲在主內(nèi)存(main memory)中,多線程讀寫volatile變量會先從高速緩存中讀取,但是寫入的時候會立即通過內(nèi)存總線刷到主存,同時內(nèi)存總...
摘要:開篇說明本文分析采用的是約定下面內(nèi)容中代表的是引用地址,引用對應(yīng)的節(jié)點(diǎn)前面已經(jīng)講解了公平模式的內(nèi)容,今天來講解下關(guān)于非公平模式下的是如何進(jìn)行工作的,在源碼分析的時候,先來簡單看一下非公平模式的簡單原理,它采用的棧這種先進(jìn)后出的方式進(jìn)行非公 開篇 說明:本文分析采用的是jdk1.8約定:下面內(nèi)容中Ref-xxx代表的是引用地址,引用對應(yīng)的節(jié)點(diǎn) 前面已經(jīng)講解了公平模式的內(nèi)容,今天來講解下...
摘要:對于偽共享的傳統(tǒng)解決方案微信公眾號技術(shù)棧以上使用此方法的某個版本對偽共享做了優(yōu)化以下使用此方法中的解決方案中已經(jīng)提供了官方的解決方案,中新增了一個注解。 1. 什么是偽共享 CPU 緩存系統(tǒng)中是以緩存行(cache line)為單位存儲的。目前主流的 CPU Cache 的 Cache Line 大小都是 64 Bytes。在多線程情況下,如果需要修改共享同一個緩存行的變量,就會無意中...
摘要:但是單核我們還是要應(yīng)用多線程,就是為了防止阻塞。多線程可以防止這個問題,多條線程同時運(yùn)行,哪怕一條線程的代碼執(zhí)行讀取數(shù)據(jù)阻塞,也不會影響其它任務(wù)的執(zhí)行。 1、多線程有什么用?一個可能在很多人看來很扯淡的一個問題:我會用多線程就好了,還管它有什么用?在我看來,這個回答更扯淡。所謂知其然知其所以然,會用只是知其然,為什么用才是知其所以然,只有達(dá)到知其然知其所以然的程度才可以說是把一個知識點(diǎn)...
閱讀 2097·2023-04-26 00:09
閱讀 3115·2021-09-26 10:12
閱讀 3481·2019-08-30 15:44
閱讀 2863·2019-08-30 13:47
閱讀 922·2019-08-23 17:56
閱讀 3226·2019-08-23 15:31
閱讀 475·2019-08-23 13:47
閱讀 2508·2019-08-23 11:56