麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

JVM運行數據環境

2019-11-10 19:34:50
字體:
來源:轉載
供稿:網友

JVM(java virual machine)Java虛擬機是Java語言的基礎,雖然名稱叫做java虛擬機,但是跟Java語言并沒有強相關,JVM主要提供一種執行字節碼(class文件的載體),很多其他的語言例如python都有基于jvm的實現版本,JVM在很多時候給我們提供了便利,屏蔽了很多細節,尤其是垃圾回收與跨平臺與多線程機制.

JVM的基本結構如下: 這里寫圖片描述

它處于連接基本類庫與字節碼文件和操作系統之間的位置.jvm也是Java語言跨平臺的基礎.

Java整個語言體系如圖:

這里寫圖片描述

jdk中的jre首先用編譯器講我們編寫的Java文件編譯成class字節碼文件,然后JVM加載字節碼文件進行解釋執行.不針對特定平臺進行編程,因為每個平臺都應該應該依賴JVM規范進行JVM實現.因此抽象出的公共接口暴露給程序調用的規范是統一的.

這里寫圖片描述

前面也提過,JVM并不認識特定的語言,而是只認識字節碼文件,JVM規范對字節碼文件格式進行嚴格的控制,這直接關系到JVM的安全性.依照特定的規則在執行引擎的處理下,JVM完成類加載,將靜態的類文件映射到虛擬機的運行數據環境.

類加載如下:

這里寫圖片描述

到了運行數據區,這里就是JVM進行管理的主要內存區域了,這里主要分為6個部分:程序計數器,虛擬機棧區,本地方法棧區,堆區,方法區,運行時常量池.

主要結構如圖: 這里寫圖片描述 接下來分別介紹6個數據區的主要用途:

1. 程序計數器

程序計數器占用的大小比較小,每個線程都會創建自己的程序計數器,當然它的生存周期也就跟線程的生存周期保持一直了,它的主要用途是跟蹤程序方法執行的路徑,它記錄了當前方法執行的操作和位置,在進行多線程調度的時候是需要進行CPU分片的,有了程序計數器就可以保護線程的執行情況,當獲得CPU使用權的時候能夠進行線程恢復.它一般存放的指令為:分支、循環、跳轉、異常處理等指令.如果是不是本地方法,這里存放就是字節碼指令的地址,如果是本地方法,它的值是undefined.這個區域通常來說比較小,也是JVM唯一沒有規定OutOfMemoryError的區域.

2.虛擬機棧區

 這個區域也是線程私有的區域,當每個方法進行執行的時候都會在棧區創建棧幀(stack frame),棧幀一般存放的局部變量表,操作數棧,動態連接與方法出口等信息.局部變量表存放的方法入口還有在編譯器就確定的基本數據類型(long與double類型占用兩個slot,其余占用一個)和引用類型和returnAddress類型(eturnAddress類型會被Java虛擬機的jsr、ret和jsr_w指令所使用。returnAddress類型的值指向一條虛擬機指令的操作碼。與前面介紹的那些數值類的原生類型不同,returnAddress類型在Java語言之中并不存在相應的類型,也無法在程序運行期間更改returnAddress類型的值。)這個區域確定了兩種異常情況,當方法調用深度超過JVM的允許值會拋出StackOverflow,如果動態的擴展無法申請到足夠多的內存也會拋出OutOfMemoryError,虛擬機規范并沒要求這個區域是否可擴展,但大部分實現的虛擬都是可擴展的.

3.本地方法棧

 本地方法棧與虛擬機棧基本一直,主要區別一個管理的目標是字節碼定義的方法棧,本地方法棧管理的是本地方法.這個區域的規范并不強制語言與數據結構,給跨平臺提供靈活的選擇性.

4.堆

 這是虛擬機中最大的一塊區域,也是開發者所指的JVM內存的主要含義,不僅僅是因為它所占比例一般最大,更重要的是垃圾回收的目標也主要在這個區域,這個區按照規范的定義是存放實例的唯一區域,但是隨著最新的技術發展(JIT技術與逃逸)發展,對象也不一定在這個區域存放.這個區域也是多個線程共享的,因此也會帶來多線程并發的復雜性.保持對象的一致性也是控制堆上的對象能夠對多個線程保持數據的一致.堆上主要存放對象實例和數組,當JVM啟動的時候就存在了堆區域,這與棧區不太一樣,棧是在方法開始調用的時候才開始創建.堆中的垃圾回收根據對象生存周期的不同來進行分代收集,主要的收集算法也有標記-清除,復制-整理,復制-壓縮等算法,根據這些算法也有一些串行,并行,甚至并發的垃圾收集器.在主流hotspot也分為年輕代(可以分為Eden和Survivor)和老年代.這個區域可以是連續的內存也可以只是邏輯連續的.

5.方法區

 這個區域主要存放被JVM加載的類的信息,包括常量,靜態變量,即時編譯后的代碼,這個區域垃圾回收效果收益不大但是是必要的.主要的收集對象為常量和需要卸載的類,類的回收機制有特定的要求.,并且十分的嚴苛.這個區域別名為Non-heap.在hotspot中使用堆中的永久區(其他JVM實現一般沒所謂的永久區)來實現方法區,這樣將垃圾回收器直接覆蓋到了堆中的方法區(hotspot中的永久區),省去了專門為永久區進行垃圾收集的工作,但是這樣增加了堆溢出的風險,因此現在jdk逐漸講方法區移除到堆外.

6.運行時常量池

 屬于方法區的一個部分,存放Class類編譯器各種能夠確定的字面量和符號引用(和直接引用).字節碼格式中一般對其他區域要求嚴格,這個區域是比較寬松的.受到方法區大小限制,申請不到足夠的內存也會拋出OutOfMemoryError異常.

7.堆外內存(直接內存)

 有些時候我們可以直接使用堆外內存,例如jdk1.4引入的java nio就用channel與buffer調用本地方法在堆外分配內存,使用堆上的DirectByteBuffer作為引用進行操作,這樣減少了堆內外數據交換,提升性能.當然這個區域的大小受到物理內存大小限制,申請不夠拋出OutOfMemoryError異常.


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久久精品福利 | 午夜视频在线观看免费视频 | 毛片三区 | xxxx hd videos| 欧美三级欧美成人高清www | 久久精品中文字幕一区二区三区 | 中文字幕欧美一区二区三区 | 精品一区二区三区四区在线 | 毛片在线看免费 | 精品在线观看一区 | 精品久久久久久久久久 | 成人午夜免费观看 | 免费一级特黄毛片视频 | 黄色a级片免费观看 | 久久毛片免费观看 | 成人在线观看一区二区 | 欧美成人性生活 | 一级毛片免费版 | 久久精品资源 | 日韩美女电影 | 久久久久久久黄色片 | 双性精h调教灌尿打屁股的文案 | 日本精品久久久久 | 久久久国产精品免费观看 | 羞羞答答tv| 国产亚洲欧美一区久久久在 | 一边吃奶一边摸下娇喘 | 日本s级毛片免费观看 | 中国的免费的视频 | 国产精品入口夜色视频大尺度 | 久久美女色视频 | 欧美黄色大片免费观看 | 四虎久草 | 成人免费在线播放 | 国产精品成人av片免费看最爱 | 欧美日韩中文字幕在线视频 | 日韩欧美高清一区 | 成人毛片在线免费观看 | 99视频观看| 精品三区视频 | 久久欧美亚洲另类专区91大神 |