| Java學習分享知識點:Java內(nèi)存模型 |
![]() |
價格: 元(人民幣) | 產(chǎn)地:本地 |
| 最少起訂量:1個 | 發(fā)貨地:本地至全國 | |
| 上架時間:2018-02-24 16:27:17 | 瀏覽量:103 | |
北京千鋒互聯(lián)科技有限公司鄭州分公司
![]() |
||
| 經(jīng)營模式:商業(yè)服務 | 公司類型:集體企業(yè) | |
| 所屬行業(yè):培訓 | 主要客戶:大學生 | |
在線咨詢 ![]() |
||
| 聯(lián)系人:李云 (先生) | 手機:15303814119 |
|
電話: |
傳真: |
| 郵箱:2051264377@qq.com | 地址:鄭州市金水區(qū)緯五路21號河南教育學院綜合樓(經(jīng)緯中學樓)7/8層 |
|
Java具有簡單性、面向?qū)ο蟆⒎植际健⒔研浴踩浴⑵脚_獨立與可移植性、多線程、動態(tài)性等特點。當然Java內(nèi)存模型不僅是Java重點要學習的技術(shù)知識,還是面試的時候經(jīng)典面試題,希望引起同學們的重視,今天千鋒小編就來分享一下Java內(nèi)存模型的相關(guān)技術(shù)知識。
不同的渠道,內(nèi)存模型是不一樣的,但是jvm的內(nèi)存模型標準是一致的。其實Java的多線程并發(fā)問題都會反映在Java的內(nèi)存模型上,所謂線程安全無非是要操控多個線程對某個資源的有序拜訪或修改。總結(jié)Java的內(nèi)存模型,要解決兩個首要的問題:可見性和有序性。 可見性: 多個線程之間是不能相互傳遞數(shù)據(jù)通信的,它們之間的交流只能經(jīng)過同享變量來進行。Java內(nèi)存模型(JMM)規(guī)定了jvm有主內(nèi)存,主內(nèi)存是多個線程同享 的。當new一個目標的時分,也是被分配在主內(nèi)存中,每個線程都有自己的作業(yè)內(nèi)存,作業(yè)內(nèi)存存儲了主存的某些目標的副本,當然線程的作業(yè)內(nèi)存大小是有限制的。當線程操作某個目標時,履行次序如下: (1) 從主存仿制變量到當前作業(yè)內(nèi)存 (read and load) (2) 履行代碼,改動同享變量值 (use and assign) (3) 用作業(yè)內(nèi)存數(shù)據(jù)改寫主存相關(guān)內(nèi)容 (store and write) 當一個同享變量在多個線程的作業(yè)內(nèi)存中都有副本時,如果一個線程修改了這個同享變量,那么其他線程應該可以看到這個被修改后的值,這就是多線程的可見性問題。 有序性:線程在引證變量時不能直接從主內(nèi)存中引證,如果線程作業(yè)內(nèi)存中沒有該變量,則會從主內(nèi)存中復制一個副本到作業(yè)內(nèi)存中,完成后線程會引證該副本。當同一線程再度引證該字段時,有可能從頭從主存中獲取變量副本(read-load-use),也有可能直接引證本來的副本 (use),也就是說 read,load,use次序可以由JVM完成體系決議。
線程不能直接為主存中字段賦值,它會將值指定給作業(yè)內(nèi)存中的變量副本(assign),完成后這個變量副本會同步到主存儲區(qū)(store- write),至于何時同步往昔,依據(jù)JVM完成體系決議。有該字段,則會從主內(nèi)存中將該字段賦值到作業(yè)內(nèi)存中,這個進程為read-load,完成后線 程會引證該變量副本。 知識就財富,這句話再IT行業(yè)顯示的尤其現(xiàn)實殘酷,懂就是懂,不懂就是不懂,所以各位同學,你的努力與否與你財富直接掛鉤。一起加油吧! |
| 版權(quán)聲明:以上所展示的信息由會員自行提供,內(nèi)容的真實性、準確性和合法性由發(fā)布會員負責。機電之家對此不承擔任何責任。 友情提醒:為規(guī)避購買風險,建議您在購買相關(guān)產(chǎn)品前務必確認供應商資質(zhì)及產(chǎn)品質(zhì)量。 |
機電之家網(wǎng) - 機電行業(yè)權(quán)威網(wǎng)絡(luò)宣傳媒體
關(guān)于我們 | 聯(lián)系我們 | 廣告合作 | 付款方式 | 使用幫助 | 會員助手 | 免費鏈接Copyright 2026 jdzj.com All Rights Reserved??技術(shù)支持:機電之家 服務熱線:0571-87774297
網(wǎng)站經(jīng)營許可證:浙B2-20080178