电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

詳解Java中的內存屏障

瀏覽:36日期:2022-08-13 09:27:53
為什么要有內存屏障

這個是為了解決因為cpu,高速緩存,主內存出現的時候,導致的可見性和重序性問題,什么問題呢,看下面我們都知道計算機運算任務需要CPU和內存相互配合共同完成,其中CPU負責邏輯計算,內存負責數據存儲。CPU要與內存進行交互,如讀取運算數據、存儲運算結果等。由于內存和CPU的計算速度有幾個數量級的差距,為了提高CPU的利用率,現代處理器結構都加入了一層讀寫速度盡可能接近CPU運算速度的高速緩存來作為內存與CPU之間的緩沖:將運算需要使用的數據復制到緩存中,讓CPU運算可以快速進行,計算結束后再將計算結果從緩存同步到主內存中,這樣處理器就無須等待緩慢的內存讀寫了。就像下面這樣

詳解Java中的內存屏障

高速緩存的引入解決了CPU和內存之間速度的矛盾,但是在多CPU系統中也帶來了新的問題:可見性問題和重排序問題。

首先是可見性問題:假設有兩個線程A、B分別在兩個不同的CPU上運行,它們共享同一個變量X。如果線程A對X進行修改后,并沒有將X更新后的結果同步到主內存,則變量X的修改對B線程是不可見的。這樣就會造成可見性問題

然后是重排序問題:假設A、B兩個線程共享兩個變量X、Y,A和B分別在不同的CPU上運行。在A中先更改變量X的值放到高速緩存區,然后再更改變量Y的值放到高速緩存區。這時有可能發生Y的值被同步回主內存,而X的值沒有同步回主內存的情況,此時對于B線程來說是無法感知到X變量被修改的,或者可以認為對于B線程來說,Y變量的修改被重排序到了X變量修改的前面。

就是為了解決上面的多線程里面的可見性和重序性問題,所以有了下面的內存屏障技術

內存屏障的主要組成

首先是硬件上面的內存屏障

Load屏障,是x86上的”ifence“指令,在其他指令前插入ifence指令,可以讓高速緩存中的數據失效,強制當前線程從主內存里面加載數據 Store屏障,是x86的”sfence“指令,在其他指令后插入sfence指令,能讓當前線程寫入高速緩存中的最新數據更新寫入主內存,讓其他線程可見。Java里面的內存屏障

在java里面有4種,就是 LoadLoad,StoreStore,LoadStore,StoreLoad,實際上也能看出來,這四種都是上面的兩種的組合產生的

LoadLoad屏障:

舉例語句是Load1; LoadLoad; Load2(這句里面的LoadLoad里面的第一個Load對應Load1加載代碼,然后LoadLoad里面的第二個Load對應Load2加載代碼),此時的意思就是在Load2加載代碼在要讀取的數據之前,保證Load1加載代碼要從主內存里面讀取的數據讀取完畢。

StoreStore屏障:

舉例語句是 Store1; StoreStore; Store2(這句里面的StoreStore里面的第一個Store對應Store1存儲代碼,然后StoreStore里面的第二個Store對應Store2存儲代碼)。此時的意思就是在Store2存儲代碼進行寫入操作執行前,保證Store1的寫入操作已經把數據寫入到主內存里面,確認Store1的寫入操作對其它處理器可見。

LoadStore屏障:

舉例語句是 Load1; LoadStore; Store2(這句里面的LoadStore里面的Load對應Load1加載代碼,然后LoadStore里面的Store對應Store2存儲代碼),此時的意思就是在Store2存儲代碼進行寫入操作執行前,保證Load1加載代碼要從主內存里面讀取的數據讀取完畢。

舉例語句是 Load1; LoadStore; Store2(這句里面的LoadStore里面的Load對應Load1加載代碼,然后LoadStore里面的Store對應Store2存儲代碼),此時的意思就是在Store2存儲代碼進行寫入操作執行前,保證Load1加載代碼要從主內存里面讀取的數據讀取完畢。

StoreLoad屏障:

舉例語句是Store1; StoreLoad; Load2(這句里面的StoreLoad里面的Store對應Store1存儲代碼,然后StoreLoad里面的Load對應Load2加載代碼),在Load2加載代碼在從主內存里面讀取的數據之前,保證Store1的寫入操作已經把數據寫入到主內存里面,確認Store1的寫入操作對其它處理器可見。

Volatile關鍵字里面的內存屏障是起作用的

在每個volatile寫操作前插入StoreStore屏障,這樣就能讓其他線程修改A變量后,把修改的值對當前線程可見,在寫操作后插入StoreLoad屏障,這樣就能讓其他線程獲取A變量的時候,能夠獲取到已經被當前線程修改的值

在每個volatile讀操作前插入LoadLoad屏障,這樣就能讓當前線程獲取A變量的時候,保證其他線程也都能獲取到相同的值,這樣所有的線程讀取的數據就一樣了,在讀操作后插入LoadStore屏障;這樣就能讓當前線程在其他線程修改A變量的值之前,獲取到主內存里面A變量的的值。

以上就是詳解Java中的內存屏障的詳細內容,更多關于Java 內存屏障的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 免费网站网址收录网_海企优网站推荐平台 | 山东钢格板|栅格板生产厂家供应商-日照森亿钢格板有限公司 | 基本型顶空进样器-全自动热脱附解吸仪价格-AutoHS全模式-成都科林分析技术有限公司 | 高低温老化试验机-步入式/低温恒温恒湿试验机-百科 | 高精度-恒温冷水机-螺杆式冰水机-蒸发冷冷水机-北京蓝海神骏科技有限公司 | 微型实验室真空泵-无油干式真空泵-微型涡旋耐腐蚀压缩机-思科涡旋科技(杭州)有限公司 | 信阳网站建设专家-信阳时代网联-【信阳网站建设百度推广优质服务提供商】信阳网站建设|信阳网络公司|信阳网络营销推广 | 工业制氮机_psa制氮机厂家-宏骁智能装备科技江苏有限公司 | 风化石头制砂机_方解石制砂机_瓷砖石子制砂机_华盛铭厂家 | 西安微信朋友圈广告投放_微信朋友圈推广_西安度娘网络科技有限公司 | R507制冷剂,R22/R152a制冷剂厂家-浙江瀚凯制冷科技有限公司 | 工业硝酸钠,硝酸钠厂家-淄博「文海工贸」 | 工业风机_环保空调_冷风机_工厂车间厂房通风降温设备旺成服务平台 | 预制直埋蒸汽保温管-直埋管道-聚氨酯发泡保温管厂家 - 唐山市吉祥保温工贸有限公司 | 加热制冷恒温循环器-加热制冷循环油浴-杭州庚雨仪器有限公司 | 密集柜_档案密集柜_智能密集架_密集柜厂家_密集架价格-智英伟业 密集架-密集柜厂家-智能档案密集架-自动选层柜订做-河北风顺金属制品有限公司 | 北京森语科技有限公司-模型制作专家-展览展示-沙盘模型设计制作-多媒体模型软硬件开发-三维地理信息交互沙盘 | 金现代信息产业股份有限公司--数字化解决方案供应商 | 钢绞线万能材料试验机-全自动恒应力两用机-混凝土恒应力压力试验机-北京科达京威科技发展有限公司 | 经济师考试_2025中级经济师报名时间_报名入口_考试时间_华课网校经济师培训网站 | 立式矫直机_卧式矫直机-无锡金矫机械制造有限公司 | 智能垃圾箱|垃圾房|垃圾分类亭|垃圾分类箱专业生产厂家定做-宿迁市传宇环保设备有限公司 | 金属检测机_金属分离器_检针验针机_食品药品金属检探测仪器-广东善安科技 | 物流之家新闻网-最新物流新闻|物流资讯|物流政策|物流网-匡匡奈斯物流科技 | 雨燕360体育免费直播_雨燕360免费NBA直播_NBA篮球高清直播无插件-雨燕360体育直播 | 中天寰创-内蒙古钢结构厂家|门式刚架|钢结构桁架|钢结构框架|包头钢结构煤棚 | 新疆十佳旅行社_新疆旅游报价_新疆自驾跟团游-新疆中西部国际旅行社 | 设定时间记录电子秤-自动累计储存电子秤-昆山巨天仪器设备有限公司 | 慈溪麦田广告公司,提供慈溪广告设计。 | 储气罐,真空罐,缓冲罐,隔膜气压罐厂家批发价格,空压机储气罐规格型号-上海申容压力容器集团有限公司 | 液氮罐(生物液氮罐)百科-无锡爱思科 | 自动螺旋上料机厂家价格-斗式提升机定制-螺杆绞龙输送机-杰凯上料机 | 洛阳防爆合格证办理-洛阳防爆认证机构-洛阳申请国家防爆合格证-洛阳本安防爆认证代办-洛阳沪南抚防爆电气技术服务有限公司 | 成都亚克力制品,PVC板,双色板雕刻加工,亚克力门牌,亚克力标牌,水晶字雕刻制作-零贰捌广告 | 政府园区专业委托招商平台_助力企业选址项目快速落地_东方龙商务集团 | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 成都办公室装修-办公室设计-写字楼装修设计-厂房装修-四川和信建筑装饰工程有限公司 | 电子万能试验机_液压拉力试验机_冲击疲劳试验机_材料试验机厂家-济南众标仪器设备有限公司 | 根系分析仪,大米外观品质检测仪,考种仪,藻类鉴定计数仪,叶面积仪,菌落计数仪,抑菌圈测量仪,抗生素效价测定仪,植物表型仪,冠层分析仪-杭州万深检测仪器网 | 珠光砂保温板-一体化保温板-有釉面发泡陶瓷保温板-杭州一体化建筑材料 | 单锥双螺旋混合机_双螺旋锥形混合机-无锡新洋设备科技有限公司 |