精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

面試官:說下你對方法區演變過程和內部結構的理解

開發 前端
雖然 Java 虛擬機規范把方法區描述為堆的一個邏輯部分,但是它卻有一個別名叫做 Non-Heap(非堆),目的應該是與 Java 堆區分開來。所以,方法區可以看作是一塊獨立于 Java 堆的內存空間。

[[425846]]

之前我們已經了解過“運行時數據區”的程序計數器、虛擬機棧、本地方法棧和堆空間,今天我們就來了解一下最后一個模塊——方法區。

簡介

創建對象時內存分配簡圖

《Java虛擬機規范》中明確說明:“盡管所有的方法區在邏輯上屬于堆的一部分,但一些簡單的實現可能不會選擇去進行垃圾收集或者進行壓縮。”

雖然 Java 虛擬機規范把方法區描述為堆的一個邏輯部分,但是它卻有一個別名叫做 Non-Heap(非堆),目的應該是與 Java 堆區分開來。所以,方法區可以看作是一塊獨立于 Java 堆的內存空間。

方法區與 Java 堆一樣,是各個線程共享的內存區域。方法區在 JVM 啟動時就會被創建,并且它的實際的物理內存空間是可以不連續的,關閉 JVM 就會釋放這個區域的內存。

永久代、元空間

《java虛擬機規范》對如何實現方法區,不做統一要求。例如:BEA JRockit/IBM J9 中不存在永久代的概念。而對于 HotSpot 來說,在 jdk7 及以前,習慣上把方法區的實現稱為永久代,而從 jdk8 開始,使用元空間取代了永久代。

方法區是 Java 虛擬機規范中的概念,而永久代和元空間是 HotSpot 虛擬機對方法區的一種實現。通俗點講:如果把方法區比作接口的話,那永久代和元空間可以比作實現該接口的實現類。

直接內存

永久代、元空間并不只是名字變了,內部結構也進行了調整。永久代使用的是 JVM 的內存,而元空間使用的是本地的直接內存。

直接內存并不是 JVM 運行時數據區的一部分,因此不會受到 Java 堆的限制。但是它會受到本機總內存大小以及處理器尋址空間的限制,所以如果這部分內存也被頻繁的使用,依然會導致 OOM 錯誤的出現。

方法區的大小

方法區的大小是可以進行設置的,可以選擇固定大小也可以進行擴展。

jdk7 及以前

  1. -XX:PermSize=N //方法區 (永久代) 初始分配空間,默認值為 20.75M 
  2. -XX:MaxPermSize=N //方法區 (永久代) 最大可分配空間。32位機器默認是64M,64位機器默認是82M 

jdk8及以后

默認值依賴于平臺,windows下:

  1. -XX:MetaspaceSize=N //方法區 (元空間) 初始分配空間,如果未指定此標志,則元空間將根據運行時的應用程序需求動態地重新調整大小。 
  2. -XX:MaxMetaspaceSize=N //方法區 (元空間) 最大可分配空間,默認值為 -1,即沒有限制 

與永久代很大的不同就是,如果不指定大小的話,隨著更多類的創建,虛擬機會耗盡所有可用的系統內存。

方法區的大小決定了系統可以保存多少個類,如果系統定義了太多的類,比如:加載大量的第三方 jar 包、Tomcat 部署的工程過多、大量動態生成反射類等都會導致方法區溢出,拋出內存溢出錯誤。

  • 永久代:OutOfMemoryError:PermGen space
  • 元空間:OutOfMemoryError:Metaspace

至于如何解決 OOM 異常,將在以后的文章中講解!

jvisualvm

我們可以通過 JDK 自帶的 jvisualvm 工具來查看程序加載的類文件:

  1. public class MethodAreaDemo1 { 
  2.     public static void main(String[] args) { 
  3.         System.out.println("start..."); 
  4.         try { 
  5.             Thread.sleep(1000000); 
  6.         } catch (InterruptedException e) { 
  7.             e.printStackTrace(); 
  8.         } 
  9.         System.out.println("end..."); 
  10.     } 

運行程序,可以看到一個簡單的程序就需要加載這么多的類文件。

高水位線

對于一個64位的服務器端 JVM 來說,XX:MetaspaceSize=21 就是初始的高水位線,一旦觸及這個水位線,Full GC 將會被觸發并卸載沒用的類(即這些類對應的類加載器不再存活),然后這個高水位線將會重置。

新的高水位線的值取決于 GC 后釋放了多少元空間:

  • 如果釋放的空間不足,那么在不超過 MaxMetaspaceSize 時,適當提高該值;
  • 如果釋放空間過多,則適當降低該值。

如果初始化的高水位線設置過低,高水位線調整情況會發生很多次。通過垃圾回收器的日志可以觀察到 Full GC 多次調用。為了避免頻繁地GC,建議將 -XX :MetaspaceSize 設置為一個相對較高的值。

內部結構

《深入理解Java虛擬機》書中對方法區存儲內容描述如下:它用于存儲已被虛擬機加載的類型信息、常量、靜態變量、即時編譯器編譯后的代碼緩存等。接下來我們就一起來看一下它的內部結構。

類型信息

對每個加載的類型( 類 class、接口 interface、枚舉 enum、注解 annotation),JVM 必須在方法區中存儲以下類型信息:

這個類型的完整有效名稱(全名=包名.類名)

這個類型直接父類的完整有效名(對于 interface 或是 java. lang.Object ,都沒有父類)

這個類型的修飾符( public , abstract, final 的某個子集)

這個類型直接接口的一個有序列表

域(Field)信息

  1. JVM必須在方法區中保存類型的所有域(field,也稱為屬性)的相關信息以及域的聲明順序;
  2. 域的相關信息包括:域名稱、 域類型、域修飾符(public, private,protected, static, final, volatile, transient 的某個子集)

方法(Method)信息

JVM 必須保存所有方法的以下信息,同域信息一樣包括聲明順序:

  • 方法名稱
  • 方法的返回類型(或void)
  • 方法參數的數量和類型(按順序)
  • 方法的修飾符(public, private, protected, static, final,synchronized, native , abstract 的一個子集)
  • 方法的字節碼(bytecodes)、操作數棧、局部變量表及大小( abstract 和 native 方法除外)
  • 異常表( abstract 和 native 方法除外)每個異常處理的開始位置、結束位置、代碼處理在程序計數器中的偏移地址、被捕獲的異常類的常量池索引

non-final 的類變量

  • 靜態變量和類關聯在一起,隨著類的加載而加載,他們成為類數據在邏輯上的一部分
  • 類變量被類的所有實例所共享,即使沒有類實例你也可以訪問它。

我們可以通過例子來查看:

  1. public class MethodAreaDemo2 { 
  2.     public static void main(String[] args) { 
  3.         Order order = null
  4.         order.hello(); 
  5.         System.out.println(order.count); 
  6.     } 
  7.  
  8. class Order { 
  9.     public static int count = 1; 
  10.     public static final int number = 2; 
  11.  
  12.     public static void hello() { 
  13.         System.out.println("hello!"); 
  14.     } 

運行結果為:

  1. hello! 

可以打開 IDEA 的 Terminal 窗口,在 MethodAreaDemo2.class 所在的路徑下,輸入 javap -v -p MethodAreaDemo2.class 命令

通過圖片我們可以看出被聲明為 final 的類變量的處理方法是不一樣的,全局常量在編譯的時候就被分配了。

運行時常量池

說到運行時常量池,我們先來了解一下什么是常量池表。

常量池表

一個有效的字節碼文件中除了包含類的版本信息、字段、方法以及接口等描述信息外,還包含一項信息那就是常量池表(Constant Pool Table),里邊存儲著數量值、字符串值、類引用、字段引用和方法引用。

為什么字節碼文件需要常量池?

java 源文件中的類、接口,編譯后會產生一個字節碼文件。而字節碼文件需要數據支持,通常這種數據會很大,以至于不能直接存放到字節碼中。換一種方式,可以將指向這些數據的符號引用存到字節碼文件的常量池中,這樣字節碼只需使用常量池就可以在運行時通過動態鏈接找到相應的數據并使用。

運行時常量池

運行時常量池( Runtime Constant Pool)是方法區的一部分,類加載器加載字節碼文件時,將常量池表加載進方法區的運行時常量池。運行時常量池中包含多種不同的常量,包括編譯期就已經明確的數值字面量,也包括到運行期解析后才能夠獲得的方法或者字段引用。此時不再是常量池中的符號地址了,這里換為真實地址。

運行時常量池,相對于 Class 文件常量池的另一重要特征是:具備動態性,比如 String.intern()。

演進細節

針對的是 Hotspot 的虛擬機:

  • jdk1.6 及之前:有永久代 ,靜態變量存放在永久代上;
  • jdk1.7:有永久代,但已經逐步“去永久代”,字符串常量池、靜態變量移除,保存在堆中;
  • jdk1.8及之后:無永久代,類型信息、字段、方法、常量保存在本地內存的元空間,但字符串常量池、靜態變量仍在堆中;

演變示例圖

為什么要將永久代替換為元空間呢?

永久代使用的是 JVM 的內存,受 JVM 設置的內存大小限制;元空間使用的是本地直接內存,它的最大可分配空間是系統可用內存的空間。因為元空間里存放的是類的元數據,所以隨著內存空間的增大,能加載的類就更多了,相應的溢出的機率會大大減小。

在 JDK8,合并 HotSpot 和 JRockit 的代碼時,JRockit 從來沒有一個叫永久代的東西,合并之后就沒有必要額外的設置這么一個永久代的地方了。

對永久代進行調優是很困難的。

StringTable 為什么要調整

因為永久代的回收效率很低,在 full gc 的時候才會觸發。而 full GC 是老年代的空間不足、永久代不足時才會觸發。這就導致了StringTable 回收效率不高。而我們開發中會有大量的字符串被創建,回收效率低,導致永久代內存不足。放到堆里,能及時回收內存。

垃圾回收

相對而言,垃圾收集行為在這個區域是比較少出現的,但并非數據進入方法區后就“永久存在”了。方法區的垃圾收集主要回收兩部分內容:常量池中廢奔的常量和不再使用的類型。

方法區內常量池中主要存放字面量和符號引用兩大類常量:

  • 字面量比較接近 Java 語言層次的常量概念,如文本字符串、被聲明為 final 的常量值等。
  • 符號引用則屬于編譯原理方面的概念,包括類和接口的全限定名、字段的名稱和描述符、方法的名稱和描述符。

HotSpot 虛擬機對常量池的回收策略是很明確的,只要常量池中的常量沒有被任何地方引用,就可以被回收。

類型判定

判定一個常量是否“廢棄”還是相對簡單,而要判定一個類型是否屬于“不再被使用的類”的條件就比較苛刻了。需要同時滿足下面三個條件:

  • 該類所有的實例都已經被回收,也就是 Java 堆中不存在該類及其任何派生子類的實例;
  • 加載該類的類加載器已經被回收,這個條件除非是經過精心設計的可替換類加載器的場景,如OSGi、JSP的重加載等,否則通常是很難達成的;
  • 該類對應的 java.lang.Class 對象沒有在任何地方被引用,無法在任何地方通過反射訪問該類的方法。

Java 虛擬機被允許對滿足上述三個條件的無用類進行回收,這里說的僅僅是“被允許”,而并不是和對象一樣,沒有引用了就必然會回收。

本文轉載自微信公眾號「阿Q說代碼」,可以通過以下二維碼關注。轉載本文請聯系阿Q說代碼公眾號。

 

責任編輯:武曉燕 來源: 阿Q說代碼
相關推薦

2025-01-13 09:24:32

2025-03-07 00:00:10

2020-05-12 23:20:50

Tomcat內部結構

2019-07-26 06:42:28

PG架構數據庫

2021-11-25 10:18:42

RESTfulJava互聯網

2021-08-09 07:47:40

Git面試版本

2024-09-27 15:43:52

零拷貝DMAIO

2020-06-12 15:50:56

options前端服務器

2020-12-01 08:47:36

Java異常開發

2025-02-21 15:25:54

虛擬線程輕量級

2025-03-21 00:00:05

Reactor設計模式I/O 機制

2024-10-24 16:14:43

數據傳輸CPU零拷貝

2025-08-18 00:00:00

零拷貝系統調用函數

2022-03-21 09:05:18

volatileCPUJava

2015-08-13 10:29:12

面試面試官

2024-09-25 12:26:14

2021-03-05 07:27:59

技術架構演變

2021-11-11 16:37:05

模板模式方法

2024-07-25 18:20:03

2025-04-09 00:00:00

點贊
收藏

51CTO技術棧公眾號

国产精品第一国产精品| www.超碰97| 精品久久国产视频| 欧美精品国产一区| 亚洲大胆人体视频| 激情综合网婷婷| 欧美激情二区| 波多野结衣精品在线| 日韩在线观看高清| 成人免费看片载| 蜜桃视频成人m3u8| 亚洲一区二区在线免费观看视频| 欧美h视频在线| 国产网址在线观看| 日韩88av| 亚洲成人av在线播放| 一区二区三区国产免费| 污污片在线免费视频| 国产女人aaa级久久久级 | av老司机在线观看| 激情久久久久久久久久久久久久久久| 欧美激情一级二级| 天堂在线中文视频| 免费福利视频一区| 日韩一区二区三区免费观看| 亚洲国产精品一区在线观看不卡 | 国内一区在线| 一区二区三区免费观看视频| 免费视频一区| 国内成人精品一区| 欧产日产国产v| 日韩欧美视频| 亚洲精品影视在线观看| 69xxx免费视频| 2019中文亚洲字幕| 欧洲精品一区二区| 免费看一级大黄情大片| 91精品久久久久久粉嫩| 日本一区二区三区在线不卡| 九九九九久久久久| 蜜臀av免费在线观看| 国产九九视频一区二区三区| 国产精品一区二区女厕厕| 天天操天天干视频| 亚洲国产美女 | h片精品在线观看| 亚洲精选视频免费看| 亚洲最大免费| 在线观看麻豆| 国产嫩草影院久久久久| 国产一区二区在线视频| 精品日韩一区二区三区| 五月天在线免费视频| 欧美老女人性开放| 91蝌蚪国产九色| 国产在线欧美日韩| 五月婷婷丁香六月| 99精品久久只有精品| 精品国产一区二区三区免费 | 看片网站欧美日韩| 精品国产一区二区三区久久久| 亚洲第一成人网站| 亚洲素人在线| 国产香蕉一区二区三区在线视频| 成人性生交大免费看| 深夜福利久久| 伊人久久久久久久久久久| 亚洲毛片亚洲毛片亚洲毛片| 欧美色网址大全| 日韩精品一区二区三区四区| 少妇精品无码一区二区| 国产精品高清乱码在线观看| 色国产精品一区在线观看| 97精品国产97久久久久久粉红| av免费在线观| 亚洲一区二区av在线| 男女激情免费视频| 亚洲国产欧美日本视频| 欧美又粗又大又爽| 人妻av中文系列| 在线观看涩涩| 精品视频一区二区不卡| 97人人爽人人| 欧美美女啪啪| 中文精品99久久国产香蕉| 国产精品白嫩白嫩大学美女| 伊人久久久大香线蕉综合直播 | 日韩av资源站| 久久久国产精品麻豆| 亚洲国产一区二区三区在线播| 国产黄a三级三级三级av在线看| 亚洲一区二区美女| 密臀av一区二区三区| 久久中文字幕一区二区| 亚洲精品乱码久久久久久金桔影视| x88av在线| 自拍偷拍欧美| 国产精国产精品| 欧美性猛交xxxxx少妇| 亚洲人www| 国产精品吴梦梦| 黄色aaa大片| 国产精品 欧美精品| 麻豆精品传媒视频| gogo在线观看| 欧美亚洲禁片免费| av av在线| 91综合在线| 欧美综合一区第一页| a在线观看视频| 久久精品亚洲一区二区三区浴池| 日韩不卡一二区| 日韩欧美精品电影| 亚洲精品成人网| 日韩一区二区不卡视频| 五月开心六月丁香综合色啪| 97精品在线视频| 国产巨乳在线观看| 精品一区二区三区免费播放 | 欧美成人一区二区三区四区| 国产激情视频一区二区三区欧美| 色女人综合av| h视频在线播放| 欧美激情综合五月色丁香| 隔壁人妻偷人bd中字| 日韩精品第二页| 亚洲欧美日韩中文在线制服| 国产真人真事毛片| 国产乱码精品一品二品| 亚洲国产成人av在线| 亚洲欧洲日本国产| 欧美freesex| 日韩经典第一页| 久久精品免费在线| 国产ts人妖一区二区| 日韩最新中文字幕| 在线视频成人| www国产精品视频| 中文字幕久久熟女蜜桃| 国产婷婷色一区二区三区| 九一国产精品视频| 久久99国产精品久久99大师| 久久99久国产精品黄毛片入口| 一本久道久久综合无码中文| 日本一区二区成人| 日韩一级片播放| 国产日产精品_国产精品毛片| 91干在线观看| 四虎影视在线观看2413| 午夜视频一区在线观看| 成人在线视频免费播放| 亚洲精品美女| 久久精品日产第一区二区三区精品版 | 超碰91在线观看| 亚洲大胆人体av| 久久久久久久久久久久久av| 99久久久国产精品免费蜜臀| 国产精品一区二区免费在线观看| 国内精品偷拍| 欧美怡春院一区二区三区| 精品国产xxx| 久久视频一区二区| 青青青国产在线视频| 色乱码一区二区三区网站| 国产精品视频免费在线| 在线观看的av| 国产精品夫妻自拍| 玖玖爱视频在线| 亚洲一区在线| 国产精品成人一区二区三区 | 成人在线日韩| 欧美成人一区二区三区电影| www.日韩在线观看| 亚洲成人精品一区二区| 日韩网站在线播放| 国产精品亚洲综合久久| 国产成人精品一区二区三区视频 | wwwav国产| 欧美丝袜丝交足nylons172| 国产精品video| 欧美高清视频| 欧美草草影院在线视频| 青青草av在线播放| 国产三级精品视频| 亚洲女人在线观看| 一区二区三区四区五区在线 | 香蕉视频免费看| 欧美影视一区二区三区| 青青操国产视频| 久久天天做天天爱综合色| 看看黄色一级片| 国产精品久久久久9999高清| 一区国产精品| 欧美成人a交片免费看| 最近2019年中文视频免费在线观看| 免费在线一级片| 久久久久国产精品免费免费搜索| 色噜噜狠狠永久免费| 伊人精品成人久久综合软件| 污视频在线免费观看一区二区三区 | 亚洲精品综合在线观看| 亚洲伦理精品| 欧美 另类 交| 你懂的视频欧美| 91精品天堂| 成人在线黄色| 韩国v欧美v日本v亚洲| 97超碰人人在线| 亚洲精品xxx| 精品久久久中文字幕人妻| 在线观看不卡一区| 69精品久久久| 亚洲三级在线免费观看| 大又大又粗又硬又爽少妇毛片| 国产在线播放一区三区四| 欧美性猛交久久久乱大交小说| 国产精品v日韩精品v欧美精品网站 | 欧美专区第二页| 亚洲欧美日韩国产一区二区| 天天综合中文字幕| 国产精品欧美日韩一区| 国产区一区二区三区| 精品午夜视频| 国产精品一区二区3区| 中文字幕在线直播| 98视频在线噜噜噜国产| 性欧美ⅴideo另类hd| 在线精品国产欧美| 国产永久av在线| 在线中文字幕一区| 久草手机在线视频| 亚洲电影中文字幕在线观看| 91久久国产综合| 中文字幕亚洲不卡| 久久一级免费视频| 中文久久乱码一区二区| 婷婷色一区二区三区| 91影院在线观看| 久久久久久久无码| av网站免费线看精品| 日本美女视频网站| 成人精品小蝌蚪| 在线精品视频播放| 成人午夜在线免费| 免费a v网站| 99视频精品免费视频| 真人bbbbbbbbb毛片| 99re成人在线| 特大黑人巨人吊xxxx| www久久久久| 国产特黄级aaaaa片免| 2020国产精品| 免费av在线一区二区| 国产精品熟女视频| 疯狂做受xxxx高潮欧美日本| 影音先锋亚洲天堂| 日韩欧美福利视频| 久久久久久久亚洲| 欧美性受xxxx黑人xyx性爽| 最新国产中文字幕| 91精品欧美久久久久久动漫| 国产精品九九九九| 欧美一区二区高清| 国 产 黄 色 大 片| 亚洲激情在线观看视频免费| 日韩一二三四| 国产亚洲一区精品| 麻豆网站在线看| 久热精品视频在线免费观看| 羞羞网站在线免费观看| 久久免费国产视频| 亚洲优女在线| 国产精品国语对白| 精品国产伦一区二区三区观看说明| 3d动漫精品啪啪一区二区三区免费| 中文字幕区一区二区三| 久久偷窥视频| 日韩av密桃| avav在线播放| 久久一区激情| 天天做天天干天天操| 成人黄色网址在线观看| 亚洲女优在线观看| 一区二区三区免费在线观看| 国产精品免费av一区二区| 欧美亚洲丝袜传媒另类| 亚洲经典一区二区三区| 亚洲免费电影一区| 超鹏97在线| 琪琪亚洲精品午夜在线| 久久伊人影院| 日本高清不卡三区| 欧美人成在线| 中文字幕永久视频| 成人性生交大片免费看视频在线| 乐播av一区二区三区| 一区二区三区四区在线免费观看| 日韩欧美成人一区二区三区| 欧美人与禽zozo性伦| 色网站在线免费观看| 久久精品久久久久久国产 免费| 国产在线精彩视频| 91亚洲国产精品| 国产精品一区二区99| 国产亚洲精品久久久久久久| 日韩av一级片| 亚洲一区二区三区黄色| 中文字幕在线观看一区二区| 亚洲精品www久久久久久| 欧美精品免费视频| 欧美老女人性开放| 久久久久国产一区二区三区| 国产香蕉久久| 品久久久久久久久久96高清| 黄片毛片在线看| 成人动漫在线一区| 亚洲天堂av中文字幕| 精品成人av一区| а√天堂资源在线| www.日韩不卡电影av| 亚洲1234区| 精品久久久久久中文字幕动漫| 欧美日本二区| 制服下的诱惑暮生| 亚洲欧美综合色| 在线视频欧美亚洲| 尤物99国产成人精品视频| 欧美91看片特黄aaaa| 精品一区二区三区视频日产| 欧美视频成人| 色婷婷狠狠18禁久久| 亚洲女人****多毛耸耸8| 在线观看中文字幕av| 亚洲欧美资源在线| 在线观看网站免费入口在线观看国内| 成人欧美一区二区| 国产精品99一区二区| 被黑人猛躁10次高潮视频| 国产精品黄色在线观看| 伊人久久成人网| 一区二区三区黄色| 欧美日韩尤物久久| 欧美一区观看| 日韩成人精品在线| 人妻av无码一区二区三区| 色综合天天综合网国产成人综合天| 天堂在线视频免费| 91成人在线播放| 小说区图片区色综合区| 欧美成人xxxxx| 91蝌蚪国产九色| 亚洲高清视频免费观看| 在线国产精品播放| 99热这里有精品| 在线观看三级网站| 粉嫩蜜臀av国产精品网站| 国产亚洲第一页| 日韩av一区二区在线| 日韩精品一区二区三区| 手机在线观看国产精品| 久久99精品国产91久久来源| 中文字幕资源站| 欧美一区二区三区视频免费| 蜜乳av一区| 久久精品国产精品国产精品污| 久久一二三四| 国产免费久久久久| 欧美成人女星排行榜| 91九色在线看| 欧美一区三区二区在线观看| 麻豆精品国产传媒mv男同| 日韩影院一区二区| 亚洲国产古装精品网站| 欧美亚洲韩国| 亚洲日本无吗高清不卡| 成人污污视频在线观看| 亚洲天堂男人av| 久久精品国产欧美激情| 成人影院中文字幕| 视频三区二区一区| 精久久久久久久久久久| 日韩精品一区二区三区丰满| 午夜日韩影院| 日韩精品一区二区三区久久| 中文在线资源观看网站视频免费不卡| 国内精品国产成人国产三级| 97久久久久久| 久久中文字幕av| 人妻换人妻a片爽麻豆| 欧美色网站导航| 超免费在线视频| 日本视频一区在线观看| 国产精品亚洲第一| 一级片在线观看免费| 麻豆一区二区在线观看| 亚洲bt欧美bt精品777| 国产一级免费大片| 欧美性xxxxx极品| 在线观看电影av| 日本午夜精品一区二区三区|