内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

Java內(nèi)存模型JMM詳解-創(chuàng)新互聯(lián)

Java Memory Model簡(jiǎn)稱JMM, 是一系列的Java虛擬機(jī)平臺(tái)對(duì)開發(fā)者提供的多線程環(huán)境下的內(nèi)存可見性、是否可以重排序等問題的無關(guān)具體平臺(tái)的統(tǒng)一的保證。(可能在術(shù)語上與Java運(yùn)行時(shí)內(nèi)存分布有歧義,后者指堆、方法區(qū)、線程棧等內(nèi)存區(qū)域)。
并發(fā)編程有多種風(fēng)格,除了CSP(通信順序進(jìn)程)、Actor等模型外,大家最熟悉的應(yīng)該是基于線程和鎖的共享內(nèi)存模型了。在多線程編程中,需要注意三類并發(fā)問題:

為原州等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及原州網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為網(wǎng)站建設(shè)、網(wǎng)站制作、原州網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

·原子性
·可見性
·重排序


原子性涉及到,一個(gè)線程執(zhí)行一個(gè)復(fù)合操作的時(shí)候,其他線程是否能夠看到中間的狀態(tài)、或進(jìn)行干擾。典型的就是i++的問題了,兩個(gè)線程同時(shí)對(duì)共享的堆內(nèi)存執(zhí)行++操作,而++操作在JVM、運(yùn)行時(shí)、CPU中的實(shí)現(xiàn)都可能是一個(gè)復(fù)合操作, 例如在JVM指令的角度來看是將i的值從堆內(nèi)存讀到操作數(shù)棧、加上一、再寫回到堆內(nèi)存的i,這幾個(gè)操作的期間,如果沒有正確的同步,其他線程也可以同時(shí)執(zhí)行,可能導(dǎo)致數(shù)據(jù)丟失等問題。常見的原子性問題又叫競(jìng)太條件,是基于一個(gè)可能失效的結(jié)果進(jìn)行判斷,如讀取-修改-寫入。 可見性和重排序問題都源于系統(tǒng)的優(yōu)化。

由于CPU的執(zhí)行速度和內(nèi)存的存取速度嚴(yán)重不匹配,為了優(yōu)化性能,基于時(shí)間局部性、空間局部性等局部性原理,CPU在和內(nèi)存間增加了多層高速緩存,當(dāng)需要取數(shù)據(jù)時(shí),CPU會(huì)先到高速緩存中查找對(duì)應(yīng)的緩存是否存在,存在則直接返回,如果不存在則到內(nèi)存中取出并保存在高速緩存中?,F(xiàn)在多核處理器越基本已經(jīng)成為標(biāo)配,這時(shí)每個(gè)處理器都有自己的緩存,這就涉及到了緩存一致性的問題,CPU有不同強(qiáng)弱的一致性模型,最強(qiáng)的一致性安全性最高,也符合我們的順序思考的模式,但是在性能上因?yàn)樾枰煌珻PU之間的協(xié)調(diào)通信就會(huì)有很多開銷。

典型的CPU緩存結(jié)構(gòu)示意圖如下

Java內(nèi)存模型JMM詳解

CPU的指令周期通常為取指令、解析指令讀取數(shù)據(jù)、執(zhí)行指令、數(shù)據(jù)寫回寄存器或內(nèi)存。串行執(zhí)行指令時(shí)其中的讀取存儲(chǔ)數(shù)據(jù)部分占用時(shí)間較長(zhǎng),所以CPU普遍采取指令流水線的方式同時(shí)執(zhí)行多個(gè)指令, 提高整體吞吐率,就像工廠流水線一樣。

Java內(nèi)存模型JMM詳解

讀取數(shù)據(jù)和寫回?cái)?shù)據(jù)到內(nèi)存相比執(zhí)行指令的速度不在一個(gè)數(shù)量級(jí)上,所以CPU使用寄存器、高速緩存作為緩存和緩沖,在從內(nèi)存中讀取數(shù)據(jù)時(shí),會(huì)讀取一個(gè)緩存行(cache line)的數(shù)據(jù)(類似磁盤讀取讀取一個(gè)block)。數(shù)據(jù)寫回的模塊在舊數(shù)據(jù)沒有在緩存中的情況下會(huì)將存儲(chǔ)請(qǐng)求放入一個(gè)store buffer中繼續(xù)執(zhí)行指令周期的下一個(gè)階段,如果存在于緩存中則會(huì)更新緩存,緩存中的數(shù)據(jù)會(huì)根據(jù)一定策略flush到內(nèi)存。

public class MemoryModel {
  private int count;
  private boolean stop;
  public void initCountAndStop() {
    count = 1;
    stop = false;
  }
  public void doLoop() {
    while(!stop) {
      count++;
    }
  }
  public void printResult() {
    System.out.println(count);
    System.out.println(stop);
  }
}

新聞名稱:Java內(nèi)存模型JMM詳解-創(chuàng)新互聯(lián)
瀏覽路徑:http://www.rwnh.cn/article44/coiihe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)、全網(wǎng)營(yíng)銷推廣、App設(shè)計(jì)、靜態(tài)網(wǎng)站網(wǎng)站設(shè)計(jì)、網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
文水县| 常德市| 县级市| 扎兰屯市| 思茅市| 大埔区| 濮阳市| 托克逊县| 西林县| 泽州县| 成武县| 元谋县| 高碑店市| 乃东县| 彭州市| 伊金霍洛旗| 金堂县| 新津县| 威海市| 益阳市| 乌鲁木齐县| 东宁县| 鄱阳县| 博罗县| 田阳县| 蕲春县| 绥江县| 浦城县| 隆化县| 嘉善县| 无锡市| 台北县| 治县。| 关岭| 南城县| 永清县| 霍邱县| 左贡县| 牟定县| 华安县| 宜城市|