欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

JVM架構體系與GC命令都有哪些

這篇文章將為大家詳細講解有關JVM架構體系與GC命令都有哪些,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

創(chuàng)新互聯(lián)是一家專業(yè)提供松江企業(yè)網(wǎng)站建設,專注與成都網(wǎng)站設計、成都網(wǎng)站制作、H5技術、小程序制作等業(yè)務。10年已為松江眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進行中。

JVM運行時數(shù)據(jù)區(qū)

JVM架構體系與GC命令都有哪些

Overview

Java虛擬機Java virtual machine(JVM)  是物理機器的軟件實現(xiàn)。java編譯器javac將源碼文件.java編譯成字節(jié)碼文件.class,然后這個字節(jié)碼文件.class被放到JVM中,裝載并執(zhí)行字節(jié)碼文件.class。JVM架構圖如下。

JVM架構體系與GC命令都有哪些

JVM Architecture

JVM架構體系

垃圾回收(garbage collection):負責回收堆內存heap中沒有被使用的對象

判斷對象是否存活,可達性檢測

  • 引用計數(shù)算法:給對象添加一個引用計數(shù)器,每當有一個地方引用它時,計數(shù)器值就加1,當引用失效時,計數(shù)器值就減1。任何時刻計數(shù)器為0的對象就是不可能再被使用的

  • 根搜索算法:通過一系列名為“GC Roots”的對象作為起始點,從這些節(jié)點開始向下搜索,搜索所走過的路徑稱為引用鏈,當一個對象到 GC Roots  沒有任何引用鏈相連時,就證明此對象是不可用的

JVM架構體系與GC命令都有哪些

垃圾回收算法

  • 標記-清除算法Mark-Sweep:首先標記出所有需要回收的對象,在標記完成后統(tǒng)一回收所有被標記的對象

  • 效率問題:標記和清除動作都不是高效動作

  • 空間問題:標記清除之后產生大量不連續(xù)的內存碎片,碎片太多導致分配較大對象時無法找到足夠的連續(xù)內存而不得不提前觸發(fā)另一次gc

  • 復制算法Copying:它將可用內存按容量劃分為大小相等的兩塊,每次只使用其中的一塊。當這一塊的內存用完了,就將還存活著的對象復制到另外一塊上面,然后再把已使用過的內存空間一次清理掉

可用內存縮小為原來的一半

每次收集時,所有的標記對象都要被拷貝,從而導致一些生命周期很長的對象被來回拷貝多次,消耗大量的時間 ->分代回收來解決這個問題

分代回收算法Generational  Collecting:根據(jù)對象存活周期的不同將內存劃分為幾塊新生代:內存分為一塊較大的Eden空間和兩塊較小的Survivor空間。新建object在Eden,Eden滿時觸發(fā)YGC,Eden中存活對象被移動到S0區(qū),清空Eden;等Eden再滿載YGC,Eden和S0中的存活對象被復制到S1(復制算法保證了S1中來自Eden和S0兩部分的存活對象占用連續(xù)的內存空間,避免了碎片化);清空Eden和S0。下一輪的時候S0和S1交換角色,如此循環(huán)往復。如果對象的復制次數(shù)達到15次,該對象就會被送到老年代。老年代:對象存活率高

垃圾回收器(垃圾回收算法的具體實現(xiàn))

并行與并發(fā)

  • 并行Parallel:指多條垃圾收集線程并行工作,但此時用戶線程仍然處于等待狀態(tài)

  • 并發(fā)Concurrent:指用戶線程與垃圾收集線程同時執(zhí)行,用戶程序在繼續(xù)運行,而垃圾收集程序運行于另一個CPU上

  • 新生代minor gc:新生代內存不是很大,miinor gc回收速度一般比較快

  • 老年代major gc/ full gc:老年代內存一般比較大,用于緩存大對象,所以回收速度約minor gc的10倍以上

  • 吞吐量throughput:JVM總共運行了100分鐘,其中垃圾收集花掉1分鐘,那吞吐量就是99%,即(all-gc)/all(for batch  pipeline)

  • 停頓時間:垃圾回收器正在運行時,應用程序的暫停時間(for streaming pipeline)

回收器類型

  1. NEW

  2. serial,單線程

  3. parNew,serial多線程版

  4. Parallel Scavenge,復制算法,并行,優(yōu)先保證吞吐量,不顧及用戶STW感受,吞吐量方面優(yōu)化的系統(tǒng),停頓時間長是可以接收的。

  5. OLD/tenured

  6. Serial Old,Serial回收器的老年代版本,單線程,標記-整理算法

  7. Parallel Old,Parallel Scavenge回收器的老年代版本,多線程,標記-整理算法

  8. Concurrent Mark Sweep, CMS:優(yōu)先最短回收停頓時間,用戶體驗好,標記-清除算法

  9. NEW and OLD

  10. 關鍵點:region內存劃分,優(yōu)先級區(qū)域回收方式。優(yōu)先回收價值最大的region

  11. garbage first,  G1:它將整個Java堆劃分為多個大小相等的獨立區(qū)域(Region),雖然還保留有新生代和老年代的概念,但新生代和老年代不再是物理隔離的了,它們都是一部分Region(不需要連續(xù))的集合。

JVM架構體系與GC命令都有哪些

類裝載子系統(tǒng)(classloader  sub-system):定位和導入二進制class文件,校驗導入類的正確性,為類變量分配并初始化內存,解析符號引用

  • 啟動類加載器bootstrap classloader,負責加載JAVA_HOME/lib下的合法類文件

  • 擴展類加載器extension classloader,負責加載JAVA_HOME/lib/ext下的合法類文件

  • 應用程序類加載器application classloader,負責加載用戶路徑classpath下的合法類文件

  • 自定義類加載器user defined classloader,class MyClassLoader extends ClassLoader

  • JVM通過雙親委派模型進行類的加載,先交給其最底層父類去加載,父類無法加載時才自己試著去加載。if(parent != null)  parent.loadclass(name) 遞歸recursion,application classloader -> extension  classloader -> bootstrap classloader

  • 先看user defined  classloader是否緩存了,如果緩存了,就直接返回,如果沒有,委派父classloader去加載,如果父緩存了,就直接返回,否則再委派給父classloader;直到最后的bootstrap  classloader,如果其緩存找不到,則在其路徑下找,找到則至二級返回,否則往其子類返回,讓其子類在其路徑下找;最后又回到自定義classloader,如果還找不到就拋異常

JVM架構體系與GC命令都有哪些

執(zhí)行引擎(execution engine):執(zhí)行classloader中的方法指令

  • 解釋器Interpreter:讀取源碼或字節(jié)碼,并逐條直接執(zhí)行(javac是在JVM外的)

  • 即時編譯器Just-In-Time compiler/JIT: 讀取源碼,更多情況下是字節(jié)碼,然后即時編譯為機器碼并執(zhí)行

  • Java虛擬機是可運行Java代碼的假想計算機,java源文件(.java)通過java編譯器javac生成字節(jié)碼文件(.class),字節(jié)碼文件(.class)通過JVM中的解釋器再翻譯成特定機器上的機器碼

即,源碼/源代碼/Source code/.java -> 字節(jié)碼/Bytecode/.class -> 機器碼/Machine  code/原生碼/Native Code

JVM架構體系與GC命令都有哪些

運行時數(shù)據(jù)區(qū)(runtime data areas):JVM運行時需要從整個計算機內存中劃出一塊內存區(qū)域存儲jvm需要用到的東西

  • 堆Heap:JVM內共享/線程間共享,保存了所有類實例/對象本身instance,不存儲基本數(shù)據(jù)類型對象和自定義對象引用(這些存在各線程的JVM  Stack中),是gc的主要回收區(qū)

  • 方法區(qū)Method Area/永久代Permanent  Generation:JVM內共享/線程間共享,保存了每個類的信息(類的名稱、字段信息、方法信息)class、靜態(tài)變量static等

  • 程序計數(shù)器Program Counter  Register/PC寄存器:線程內共享,保存每個線程正在執(zhí)行的虛擬機字節(jié)碼指令的地址;若該方法為Native的,則計數(shù)器置空Undefined

  • 虛擬機棧JVM Stack/線程棧:線程內共享,保存基本數(shù)據(jù)類型的對象和自定義對象的引用,執(zhí)行環(huán)境的上下文

  • 本地方法棧Native Method Stacks:線程內共享,與JVM  Stack所發(fā)揮的作用是非常相似的,其區(qū)別不過是虛擬機棧為虛擬機執(zhí)行Java方法(也就是字節(jié)碼)服務,而本地方法棧則是為虛擬機執(zhí)行的Native方法服務

JVM架構體系與GC命令都有哪些

垃圾回收器開啟命令

Command  line新生代gc模式老年代gc模式-XX:+UseSerialGCserial串行回收器serialOld串行回收器-XX:+UseParNewGCparNew并行回收器default-XX:+UseParallelGCparallel并行回收器default-XX:+UseParallelOldGCdefaultparallel并行回收器-XX:+UseConcMarkSweepGCdefaultCMS并行回收器-XX:+UseG1GCG1回收器G1回收器

根據(jù)上表新生代與老年代的gc模式互為搭配一起為垃圾回收器服務。

關于JVM架構體系與GC命令都有哪些就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

網(wǎng)頁標題:JVM架構體系與GC命令都有哪些
分享網(wǎng)址:http://aaarwkj.com/article48/isjshp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設、自適應網(wǎng)站、營銷型網(wǎng)站建設、網(wǎng)站設計公司、微信小程序網(wǎng)站設計

廣告

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

網(wǎng)站托管運營
精品欧美一区二区三区在线| 成年免费视频一区二区三区| 青草免费在线播放视频| 亚洲黄色成人免费观看| 一级片高清在线观看国产| 青青草原精品视频在线| 国产精品第一区第二区| 久久久亚洲熟妇熟女一区二区| 美女高潮久久久777| 婷婷六月开心激情五月| 午夜丁香婷婷爽少妇av| 五月婷婷少妇中文字幕| 丰满人妻在线一区二区三区| 国产黄片自拍视频免费看| 色婷婷一区二区三区网站| 你懂的免费视频中文字幕| 五月天亚洲激情综合av| 精品国产av色一区二区| 国产亚洲精品a久久7777| 欧美黄色免费电影网站| 熟女av一区二区三区四区| 人妻免费精品久久一区| 一区二区亚洲免费的视频| 综合久久精品亚洲天堂| 亚洲国产一区二区三区三州| 亚洲成av在线免费不卡| 亚洲精品aa片在线观看国产| 白白色最新福利在线视频观看| 丰满少妇被激烈的插进去| 日本女人体内射精视频| 蜜臀人妻四季av一区二区不卡| 国产精品v一区二区三区| 亚洲欧美一区二区三区三| 亚洲精品一区二区影院| 亚洲成年人黄色在线观看| av中文字幕啊嗯不要| 久久国产精品乱码电影| av国产一区二区在线| 欧美日韩精品一区二区在线| 亚洲精品免费福利视频| 国产成人综合久久精品推荐|