真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

從5個(gè)方面讓你真正了解Java內(nèi)存模型

前言

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),羅山企業(yè)網(wǎng)站建設(shè),羅山品牌網(wǎng)站建設(shè),網(wǎng)站定制,羅山網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷,網(wǎng)絡(luò)優(yōu)化,羅山網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

首先我們?cè)诹私鈐ava內(nèi)存模型之前先看一下計(jì)算機(jī)內(nèi)存模型,理解了計(jì)算機(jī)內(nèi)存模型的話后面在看JMM就會(huì)簡(jiǎn)單的多。

從5個(gè)方面讓你真正了解Java內(nèi)存模型

計(jì)算機(jī)內(nèi)存

計(jì)算機(jī)是由CPU、主存、磁盤等組成的(簡(jiǎn)單引出問(wèn)題熬)我們都知道計(jì)算機(jī)執(zhí)行程序的指令都是由CPU來(lái)執(zhí)行的,執(zhí)行的時(shí)候是要處理數(shù)據(jù)的,這些數(shù)據(jù)通常存儲(chǔ)在主存中。

從5個(gè)方面讓你真正了解Java內(nèi)存模型

如圖所示,這時(shí)候問(wèn)題來(lái)了,CPU的執(zhí)行速度越來(lái)越快,然后內(nèi)存倒是沒(méi)什么進(jìn)展,這樣的話CPU的讀寫操作就會(huì)非常耗時(shí),效率不就很低了?

所以這個(gè)時(shí)候就出現(xiàn)了高速緩存(Cache)來(lái)解決這個(gè)問(wèn)題,那么緩存是什么呢?緩存其實(shí)就是保存的數(shù)據(jù)備存,特點(diǎn)是快。所以這個(gè)時(shí)候程序的執(zhí)行過(guò)程就變成了這個(gè)樣子:首先在運(yùn)行的時(shí)候會(huì)把數(shù)據(jù)從主存中賦值一份放在緩存中,然后CPU在運(yùn)算的時(shí)候就直接去緩存中讀寫數(shù)據(jù),等執(zhí)行結(jié)束后在把數(shù)據(jù)刷新到主存中。這樣一來(lái)就大大的提高了執(zhí)行的速度。我們來(lái)看一下流程圖:

從5個(gè)方面讓你真正了解Java內(nèi)存模型

可以看出,運(yùn)行的時(shí)候L1緩存先把數(shù)據(jù)從主存中讀取出來(lái),然后CPU操作的數(shù)據(jù)是從緩存中讀取,當(dāng)數(shù)據(jù)執(zhí)行完畢,在從緩存中刷新到主存中。隨著CPU的執(zhí)行能力越來(lái)越強(qiáng),一層緩存已經(jīng)滿足不了需求了,這時(shí)候就出現(xiàn)了2級(jí)緩存(L2Cache)3級(jí)緩存(L3Cache),每級(jí)緩存都存儲(chǔ)的是下一級(jí)緩存的一部分?jǐn)?shù)據(jù)。

那么當(dāng)CPU需要數(shù)據(jù)的時(shí)候就會(huì)這樣執(zhí)行:首先去一級(jí)緩存(L1Cache)查找,如果一級(jí)緩存沒(méi)有就去二級(jí)緩存(L2Cache)查找,二級(jí)緩存沒(méi)有就去三級(jí)緩存(L3Cache)查找,如果緩存中沒(méi)有,就去主存中查找。 那么問(wèn)題來(lái)了。

緩存一致性

現(xiàn)代計(jì)算機(jī)已經(jīng)不是單個(gè)CPU,有多個(gè)CPU每個(gè)CPU還可能會(huì)有多核,單核CPU只有一套緩存分別就是上面所說(shuō)的L1、L2、L3如圖所示:

從5個(gè)方面讓你真正了解Java內(nèi)存模型

如果CPU有多個(gè)核心的話,就是每個(gè)核心都有L1緩存或者有L2緩存,而共享L3緩存或者L2緩存。

我們來(lái)看一下結(jié)構(gòu)圖:

從5個(gè)方面讓你真正了解Java內(nèi)存模型

這個(gè)時(shí)候每個(gè)核心都有自己的高速緩存,它們又共享同一主存,就會(huì)造成緩存一致性的問(wèn)題,在多線程同時(shí)訪問(wèn)同一共享數(shù)據(jù)的情況下,每個(gè)線程都是操作自己緩存的數(shù)據(jù)副本,這個(gè)時(shí)候就會(huì)出現(xiàn)每個(gè)緩存中的共享數(shù)據(jù)存在不一致的情況。多個(gè)處理器運(yùn)算任務(wù)都涉及同一塊主存,需要一種協(xié)議可以保障數(shù)據(jù)的一致性,這類協(xié)議有MSI、MESI、MOSI及Dragon Protocol等。

處理器優(yōu)化

上面了解到提高CPU的效率就是在CPU和主存直接增加高速緩存,增加高速緩存會(huì)造成緩存不一致的問(wèn)題,除了緩存不一致的問(wèn)題,還有一種問(wèn)題就是為了能讓處理器內(nèi)部的運(yùn)算單元能夠盡量的被充分利用處理器可能會(huì)對(duì)輸入代碼進(jìn)行亂序執(zhí)行,并且處理器會(huì)在計(jì)算之后將亂序的代碼進(jìn)行結(jié)果重組來(lái)保證結(jié)果的一致性。在Java虛擬機(jī)中也有類似的指令重排序。

思考

這篇文章其實(shí)是講述java內(nèi)存模型的,為什么會(huì)和計(jì)算機(jī)硬件扯上關(guān)系呢?注意到上面有說(shuō)到多線程的情況下會(huì)造成緩存不一致的問(wèn)題,提到多線程就離不開并發(fā),想到并發(fā)的話就離不開三大問(wèn)題,可見(jiàn)性,原子性,有序性的問(wèn)題。那這三種特性不就是上面所說(shuō)到的緩存不一致,處理器優(yōu)化和指令重排序問(wèn)題嗎。這這樣看來(lái)緩存不一致不就是可見(jiàn)性的問(wèn)題,而原子性不就是處理器優(yōu)化所導(dǎo)致的原子性問(wèn)題,指令重排序就是導(dǎo)致有序性的問(wèn)題。那么Java內(nèi)存模型又是什么呢?

Java內(nèi)存模型

Java內(nèi)存模型的作用就是用來(lái)屏蔽掉不同操作系統(tǒng)中的內(nèi)存差異性來(lái)保持并發(fā)的一致性。同時(shí)JMM也規(guī)范了JVM如何與計(jì)算機(jī)內(nèi)存進(jìn)行交互。簡(jiǎn)單的來(lái)說(shuō)java內(nèi)存模型就是Java自己的一套協(xié)議來(lái)屏蔽掉各種硬件和操作系統(tǒng)的內(nèi)存訪問(wèn)差異,實(shí)現(xiàn)平臺(tái)一致性達(dá)到最終的"一次編寫,到處運(yùn)行"??吹竭@里就知道了Jmm是用來(lái)做什么的。同時(shí)Java內(nèi)存模型可以理解為java并發(fā)內(nèi)存模型。然后JMM

通信

Java內(nèi)存模型(以下簡(jiǎn)稱JMM)規(guī)定了,所有變量都存儲(chǔ)在主內(nèi)存中,每個(gè)線程都有自己的本地緩存,所以線程中對(duì)變量的操作都必須在本地緩存中進(jìn)行并不是直接操作主內(nèi)存,線程之間的無(wú)法訪問(wèn)對(duì)方線程的變量,想要通信的話就只能通過(guò)主內(nèi)存進(jìn)行通信。

JMM抽象示意圖:

從5個(gè)方面讓你真正了解Java內(nèi)存模型

從上圖可以看出每個(gè)線程都有一個(gè)本地內(nèi)存,如果線程想要通信的話要執(zhí)行一下步驟:

  • A線程先把本地內(nèi)存的值寫入主內(nèi)存

  • B線程從主內(nèi)存中去讀取出A線程寫的值

到這里就對(duì)JMM有個(gè)清晰的理解了。JMM其實(shí)是一種規(guī)范,其主要目的就是為了解決多線程通過(guò)共享內(nèi)存進(jìn)行通信時(shí)所產(chǎn)生的本地內(nèi)存數(shù)據(jù)不一致,編譯器會(huì)對(duì)代碼指令重排序、處理器會(huì)對(duì)代碼亂序執(zhí)行等帶來(lái)的問(wèn)題。歡迎大家關(guān)注我的公種浩【程序員追風(fēng)】,文章都會(huì)在里面更新,整理的資料也會(huì)放在里面。

解決的問(wèn)題

JMM所解決的問(wèn)題離不開我們上面所說(shuō)的三大特性:可見(jiàn)性、原子性、有序性.

原子性:在java中使用synchronized關(guān)鍵字保證代碼的原子性。

可見(jiàn)性:volatile關(guān)鍵字保證了多線程操控變量的可見(jiàn)性,同時(shí)synchronized和final也可以保證變量的可見(jiàn)性,注意:volatile并不保證原子性,所以什么時(shí)候用volatile一定要注意。

有序性:volatile可以禁用指令重排,synchronized關(guān)鍵字保證同一時(shí)刻只允許一條線程操作所以我們可以發(fā)現(xiàn)synchronized可以解決三種問(wèn)題,所以使用synchronized關(guān)鍵字比較多,但是synchronized只允許一個(gè)線程進(jìn)行操作,會(huì)造成上下文切換的效率問(wèn)題。

最后

歡迎大家一起交流,喜歡文章記得點(diǎn)個(gè)贊喲,感謝支持!


文章標(biāo)題:從5個(gè)方面讓你真正了解Java內(nèi)存模型
URL鏈接:http://weahome.cn/article/ihieio.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部