詳解JVM的內(nèi)存對(duì)象介紹[創(chuàng)建和訪問(wèn)]
作為java程序員對(duì)應(yīng)Object應(yīng)該是非常熟悉的,但是對(duì)于對(duì)象在JVM中的一些情況并不是很清楚,所以本文就來(lái)記錄下對(duì)象在JVM中的一些內(nèi)容
對(duì)象的創(chuàng)建
java程序中創(chuàng)建對(duì)象的常用方式是:
Object obj = new Object();
該行代碼的執(zhí)行過(guò)程如下:
從圖中我們可以發(fā)現(xiàn)對(duì)象創(chuàng)建的步驟如下
- 執(zhí)行new執(zhí)行
- 檢查這個(gè)指令參數(shù)是否能夠在常量池中定位到一個(gè)類(lèi)的符號(hào)引用,并且檢查這個(gè)符號(hào)引用所代表的類(lèi)是否已經(jīng)被加載,解析和初始化。
- 如果該類(lèi)沒(méi)有被加載則先執(zhí)行類(lèi)的加載操作
- 如果該類(lèi)已經(jīng)被加載,則開(kāi)始給該對(duì)象在jvm的堆中分配內(nèi)存。分配規(guī)則后面介紹
- 虛擬機(jī)初始化操作,虛擬機(jī)對(duì)分配的空間初始化為零值。
- 執(zhí)行init方法,初始化對(duì)象的屬性,至此對(duì)象被創(chuàng)建完成。
- java虛擬機(jī)棧中的Reference執(zhí)行我們剛剛創(chuàng)建的對(duì)象。
在上面的過(guò)程中的類(lèi)加載的過(guò)程,后面會(huì)單獨(dú)介紹,而內(nèi)存分配這塊我們來(lái)介紹下
內(nèi)存的分配原則
內(nèi)存分配的基本原則:
序號(hào) | 介紹 |
---|---|
1 | 優(yōu)先在Eden分配,如果Eden空間不足虛擬機(jī)則會(huì)進(jìn)行一次MinorGC |
2 | 大對(duì)象直接接入老年代,很長(zhǎng)的字符串或數(shù)組 |
3 | 長(zhǎng)期存活的對(duì)象進(jìn)入老年代,每個(gè)對(duì)象都有一個(gè)age,當(dāng)age到達(dá)設(shè)定的年齡的時(shí)候就會(huì)進(jìn)入老年代,默認(rèn)是15歲 |
內(nèi)存的分配方法
內(nèi)存分配的方法有兩種:指針碰撞(Bump the Pointer)和空閑列表(Free List)
分配方法 | 說(shuō)明 | 收集器 |
---|---|---|
指針碰撞 | 內(nèi)存地址是連續(xù)的 | Serial和ParNew收集器 |
空閑列表 | 內(nèi)存地址不連續(xù) | CMS收集器和Mark-Sweep收集器 |
內(nèi)存分配的安全問(wèn)題
在分配內(nèi)存的同時(shí),存在線程安全的問(wèn)題,即虛擬機(jī)給A線程分配內(nèi)存過(guò)程中,指針未修改,B線程可能同時(shí)使用了同樣一塊內(nèi)存。
在JVM中有兩種解決辦法:
- 同步處理,即CAS(compare & swap)搭配失敗重試的方式
- 將內(nèi)存分配的動(dòng)作按線程分配到不同空間中,每個(gè)線程都有一小塊內(nèi)存,成為本地線程分配緩沖(Thread Local Allocation Buffer即TLAB)。
對(duì)象的訪問(wèn)定位
建立對(duì)象是為了使用對(duì)象,java程序是通過(guò)棧上的reference數(shù)量來(lái)操作堆上的具體的對(duì)象,具體操作對(duì)象的方式有兩種:
1.通過(guò)句柄訪問(wèn)對(duì)象
2.通過(guò)直接指針訪問(wèn)對(duì)象
兩種方式的比較
方式 | 優(yōu)點(diǎn) |
---|---|
句柄 | 穩(wěn)定,對(duì)象被移動(dòng)只要修改句柄中的地址 |
直接指針 | 訪問(wèn)速度快,節(jié)省了一次指針定位的開(kāi)銷(xiāo) |
以上所述是小編給大家介紹的JVM的內(nèi)存對(duì)象介紹[創(chuàng)建和訪問(wèn)]詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Activiti7通過(guò)代碼動(dòng)態(tài)生成工作流實(shí)現(xiàn)詳解
這篇文章主要為大家介紹了Activiti7通過(guò)代碼動(dòng)態(tài)生成工作流實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11IntelliJ IDEA中出現(xiàn)"PSI and index do not match"錯(cuò)誤的解決辦法
今天小編就為大家分享一篇關(guān)于IntelliJ IDEA中出現(xiàn)"PSI and index do not match"錯(cuò)誤的解決辦法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-10-10SpringBoot+Hutool實(shí)現(xiàn)圖片驗(yàn)證碼的示例代碼
圖片驗(yàn)證碼在注冊(cè)、登錄、交易、交互等各類(lèi)場(chǎng)景中都發(fā)揮著巨大作用,本文主要介紹了SpringBoot+Hutool實(shí)現(xiàn)圖片驗(yàn)證碼的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01Java數(shù)據(jù)結(jié)構(gòu)之圖的原理與實(shí)現(xiàn)
圖(Graph)是由頂點(diǎn)的有窮非空集合和頂點(diǎn)之間邊的集合組成,通常表示為:G(V,E),其中,G表示一個(gè)圖,V是圖G中頂點(diǎn)的集合,E是圖G中邊的集合。本文將詳細(xì)介紹圖的原理及其代碼實(shí)現(xiàn),需要的可以參考一下2022-01-01spring?@Conditional的使用與擴(kuò)展源碼分析
這篇文章主要介紹了spring?@Conditional的使用與擴(kuò)展,這里需要注意如果Condition返回的是false,那么spirng就不會(huì)對(duì)方法或類(lèi)進(jìn)行解析,具體源碼分析跟隨小編一起看看吧2022-03-03springboot?實(shí)現(xiàn)接口灰度發(fā)布的實(shí)例詳解
這篇文章主要介紹了springboot?實(shí)現(xiàn)接口灰度發(fā)布,簡(jiǎn)單來(lái)說(shuō)就是能夠根據(jù)業(yè)務(wù)規(guī)則的調(diào)整交互上呈現(xiàn)不同的形式,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03Java Thread之Sleep()使用方法總結(jié)
這篇文章主要介紹了Java Thread之Sleep()使用方法總結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05