JVM運(yùn)行時(shí)數(shù)據(jù)區(qū)劃分原理詳解
Java內(nèi)存空間
內(nèi)存是非常重要的系統(tǒng)資源,是硬盤(pán)和cpu的中間倉(cāng)庫(kù)及橋梁,承載著操作系統(tǒng)和應(yīng)用程序的實(shí)時(shí)運(yùn)行。JVM內(nèi)存布局規(guī)定了JAVA在運(yùn)行過(guò)程中內(nèi)存申請(qǐng)、分配、管理的策略,保證了JVM的高效穩(wěn)定運(yùn)行。不同的jvm對(duì)于內(nèi)存的劃分方式和管理機(jī)制存在著部分差異(對(duì)于Hotspot主要指方法區(qū))
(圖源阿里)JDK8的元數(shù)據(jù)區(qū)+JIT編譯產(chǎn)物 就是JDK8以前的方法區(qū)
JavaAPI中的Runtime
public class Runtime
extends Object
Every Java application has a single instance of class Runtime that allows the application to interface with theenvironment in which the application is running. The current runtime can be obtained from the getRuntime method.
每個(gè)Java應(yīng)用程序都有一個(gè)Runtime類(lèi)的實(shí)例,該實(shí)例允許該應(yīng)用程序與運(yùn)行該應(yīng)用程序的環(huán)境進(jìn)行交互。 當(dāng)前運(yùn)行時(shí)可以從getRuntime方法獲得。Java內(nèi)存分區(qū)介紹
java虛擬機(jī)定了了若干種程序運(yùn)行期間會(huì)使用到的運(yùn)行時(shí)數(shù)據(jù)區(qū),其中有一些會(huì)隨著虛擬機(jī)啟動(dòng)而創(chuàng)建,隨著虛擬機(jī)退出而銷(xiāo)毀。另外一些則是與縣城一一對(duì)應(yīng)的,這些與線程對(duì)應(yīng)的數(shù)據(jù)區(qū)域會(huì)隨著線程開(kāi)始和結(jié)束而創(chuàng)建和銷(xiāo)毀。
如圖,灰色的區(qū)域?yàn)閱为?dú)線程私有的,紅色的為多個(gè)線程共享的,即
Java
中的線程與進(jìn)程
1.每個(gè)線程:獨(dú)立包括程序計(jì)數(shù)器、棧、本地棧
2.線程間共享:堆、堆外內(nèi)存(方法區(qū)、永久代或元空間、代碼緩存)
圖片說(shuō)明:嚴(yán)格對(duì)照J(rèn)ava內(nèi)存分區(qū)
PC即程序計(jì)數(shù)器
VMS即虛擬機(jī)棧
NMS即本地方法棧
一般來(lái)說(shuō),jvm優(yōu)化95%是優(yōu)化堆區(qū),5%優(yōu)化的是方法區(qū),至于棧區(qū)無(wú)非出入棧操作優(yōu)化較少Java線程
1.線程是一個(gè)程序里的運(yùn)行單元,JVM允許一個(gè)程序有多個(gè)線程并行的執(zhí)行;
2.在HotSpot JVM,每個(gè)線程都與操作系統(tǒng)的本地線程直接映射。
當(dāng)一個(gè)java線程準(zhǔn)備好執(zhí)行以后,此時(shí)一個(gè)操作系統(tǒng)的本地線程也同時(shí)創(chuàng)建。java線程執(zhí)行終止后。本地線程也會(huì)回收。
3.操作系統(tǒng)負(fù)責(zé)所有線程的安排調(diào)度到任何一個(gè)可用的CPU上。一旦本地線程初始化成功,它就會(huì)調(diào)用java線程中的run()方法.
JVM系統(tǒng)線程分類(lèi)
如果你使用jconsole或者任何一個(gè)調(diào)試工具,都能看到在后臺(tái)有許多線程在運(yùn)行。這些后臺(tái)線程不包括調(diào)用main方法的main線程以及所有這個(gè)main線程自己創(chuàng)建的線程;
這些主要的后臺(tái)系統(tǒng)線程在HotSpot JVM里主要是以下幾個(gè):
1.虛擬機(jī)線程:這種線程的操作時(shí)需要JVM達(dá)到安全點(diǎn)才會(huì)出現(xiàn)。這些操作必須在不同的線程中發(fā)生的原因是他們都需要JVM達(dá)到安全點(diǎn),這樣堆才不會(huì)變化。這種線程的執(zhí)行包括“stop-the-world”的垃圾收集,線程棧收集,線程掛起以及偏向鎖撤銷(xiāo)
2.周期任務(wù)線程:這種線程是時(shí)間周期事件的提現(xiàn)(比如中斷),他們一般用于周期性操作的調(diào)度執(zhí)行。
3.GC線程:這種線程對(duì)于JVM里不同種類(lèi)的垃圾收集行為提供了支持
4.編譯線程:這種線程在運(yùn)行時(shí)會(huì)降字節(jié)碼編譯成本地代碼
5.信號(hào)調(diào)度線程:這種線程接收信號(hào)并發(fā)送給JVM,在它內(nèi)部通過(guò)調(diào)用適當(dāng)?shù)姆椒ㄟM(jìn)行處理。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JAVA JVM運(yùn)行時(shí)數(shù)據(jù)區(qū)詳解
- JVM內(nèi)存模型/內(nèi)存空間:運(yùn)行時(shí)數(shù)據(jù)區(qū)
- 面試時(shí)必問(wèn)的JVM運(yùn)行時(shí)數(shù)據(jù)區(qū)詳解
- Java JVM運(yùn)行時(shí)數(shù)據(jù)區(qū)(Run-Time Data Areas)
- Java內(nèi)存模型與JVM運(yùn)行時(shí)數(shù)據(jù)區(qū)的區(qū)別詳解
- JVM運(yùn)行時(shí)數(shù)據(jù)區(qū)原理解析
- Java內(nèi)存模型JMM與volatile
- Java內(nèi)存模型(JMM)及happens-before原理
- JVM?運(yùn)行時(shí)數(shù)據(jù)區(qū)與JMM?內(nèi)存模型
相關(guān)文章
SpringBoot+Quartz實(shí)現(xiàn)動(dòng)態(tài)定時(shí)任務(wù)
這篇文章主要為大家詳細(xì)介紹了springBoot+Quartz實(shí)現(xiàn)動(dòng)態(tài)定時(shí)任務(wù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-09-09SpringBoot使用Spring-Data-Jpa實(shí)現(xiàn)CRUD操作
這篇文章主要為大家詳細(xì)介紹了SpringBoot使用Spring-Data-Jpa實(shí)現(xiàn)CRUD操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08Docker?快速部署Springboot項(xiàng)目超詳細(xì)最新版
這篇文章主要介紹了Docker?快速部署Springboot項(xiàng)目超詳細(xì)最新版的相關(guān)資料,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04Spring Data JPA 整合QueryDSL的使用案例
QueryDSL 是一個(gè)用于構(gòu)建類(lèi)型安全的 SQL 查詢(xún)的 Java 庫(kù),它的主要目標(biāo)是簡(jiǎn)化在 Java 中構(gòu)建和執(zhí)行 SQL 查詢(xún)的過(guò)程,同時(shí)提供類(lèi)型安全性和更好的編碼體驗(yàn),對(duì)Spring Data JPA 整合QueryDSL使用案例感興趣的朋友跟隨小編一起看看吧2023-08-08Java HttpServletResponse響應(yīng)實(shí)現(xiàn)過(guò)程詳解
這篇文章主要介紹了Java HttpServletResponse響應(yīng)實(shí)現(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05Java 隊(duì)列 Queue 用法實(shí)例詳解
本文實(shí)例講述了Java內(nèi)置隊(duì)列類(lèi)Queue用法,分享給大家供大家參考2017-04-04基于Spring Boot的Environment源碼理解實(shí)現(xiàn)分散配置詳解
這篇文章主要給大家介紹了基于Spring Boot的Environment源碼理解實(shí)現(xiàn)分散配置的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08SpringBoot+Mybatis使用Enum枚舉類(lèi)型總是報(bào)錯(cuò)No enum constant&n
這篇文章主要介紹了SpringBoot+Mybatis使用Enum枚舉類(lèi)型總是報(bào)錯(cuò)No enum constant XX問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12RocketMQ中消費(fèi)者概念和消費(fèi)流程詳解
這篇文章主要介紹了RocketMQ中消費(fèi)者概念和消費(fèi)流程詳解,RocketMQ是一款高性能、高可靠性的分布式消息中間件,消費(fèi)者是RocketMQ中的重要組成部分,消費(fèi)者負(fù)責(zé)從消息隊(duì)列中獲取消息并進(jìn)行處理,需要的朋友可以參考下2023-10-10