bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

Java內存區域與內存溢出異常知識講解

本篇內容介紹了“Java內存區域與內存溢出異常知識講解”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

創新互聯專業為企業提供龍里網站建設、龍里做網站、龍里網站設計、龍里網站制作等企業網站建設、網頁設計與制作、龍里企業網站模板建站服務,10多年龍里做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。

正文

一. 基本概念

在開始講解之前, 需要先明確關于 JVM 的一些基本概念

我們都知道, Java 是一個跨平臺的語言, Java 跨平臺的基本支撐其實就是 JVM 對操作系統底層細節的屏蔽, 相當于加了一個中間層(計算機中的任何問題都可以加一個中間層解決~), Java 不再像 C/C++ 等語言一樣直接翻譯為針對特殊平臺的機器碼, 而是翻譯為字節碼, 也即是我們的 class 文件, 下圖大概可以比較簡明的概括了~; 字節碼就相當于 Java 世界中的匯編, 而 JVM 則不是跨平臺的, 只是不同平臺的 JVM 都能識別和運行標準格式的字節碼文件而已

Java內存區域與內存溢出異常知識講解

關于 JVM 運行 class 文件, 我覺得下圖已經可以比較準確的表達了

Java內存區域與內存溢出異常知識講解

我們下面要講的就是 Runtime Data Area 部分

二. 運行時數據區

JVM 會在執行 Java 程序的時候把它所管理的內存劃分為若干個不同的數據區, 如下:

Java內存區域與內存溢出異常知識講解

2.1 程序計數器

線程私有

2.1.1 存儲數據類型

指向下一條需要執行的字節碼指令; 如果線程正在執行一個 Java 方法, 該計數器記錄的是正在執行的虛擬機字節碼指令的地址; 如果正在執行 Native 方法, 該計數器值則為空( Undefined )

2.1.2 異常情況

該區域是是唯一一個在 Java 虛擬機中沒有規定任何 OutOfMemoryError 情況的區域

2.2 Java虛擬機棧

線程私有

2.2.1 存儲數據類型

描述 Java 方法執行的內存模型, 每個方法調用就對應著一個棧幀的入棧和出棧; 一個棧幀里面存儲了局部變量表, 操作數棧, 動態鏈接, 方法出口等信息

局部變量表存儲了編譯器可知的各種基本數據類型, 對象引用, returnAddress ; 局部變量表的大小在編譯期間即可確定, 運行期間大小不變

2.2.2 異常情況
  1. StackOverflowError : 線程請求棧深度大于虛擬機允許深度

異常示例代碼:

public class JavaVMStackSOF {    private int stackLength = 1;    public void stackLeak() {
        stackLength++;
        stackLeak();
    }    public static void main(String[] args) {
        JavaVMStackSOF sof = new JavaVMStackSOF();        try {
            sof.stackLeak();
        } catch (Throwable e) {
            System.out.println("Stack Length: " + sof.stackLength);            throw e;
        }
    }
}
  1. OutOfMemoryError : 虛擬機棧動態擴展時無法申請到足夠內存

異常示例代碼:

public class JavaVMStackOOM {    private void dontStop() {        while (true) {
        }
    }    public void stackLeakByThread() {        while (true) {            new Thread(new Runnable() {                @Override
                public void run() {
                    dontStop();
                }
            }).start();
        }
    }    public static void main(String[] args) {
        JavaVMStackOOM oom = new JavaVMStackOOM();
        oom.stackLeakByThread();
    }
}

注: 由于操作系統分配給每個進程的內存空間是有限制的, 所以如果是由于建立過多的線程導致內存溢出, 在不能減少線程數或者更換 64 位虛擬機的情況下, 可以選擇通過減少最大堆和減少棧容量來換取更多的線程

2.3 本地方法棧

線程私有

2.3.1 存儲數據類型

和虛擬機棧類似, 只是本地方法棧提供的是 Native 方法服務

2.3.2 異常情況

StackOverflowError 和 OutOfMemoryError

2.4 Java堆

  1. 線程共享

  2. 垃圾收集管理的主要區域

2.4.1 存儲數據類型

幾乎所有的對象實例都在這里分配

2.4.2 異常情況

OutOfMemoryError

異常示例:

public class JavaVMHeapOOM {    static class HeapOOM {
    }    public static void main(String[] args) {        List<HeapOOM> list = new ArrayList();        while (true) {            list.add(new HeapOOM());
        }
    }
}

2.5 方法區

  1. 線程共享

  2. 該區域的垃圾回收目標主要是針對常量池的回收和對類型的卸載

2.5.1 存儲數據類型

存儲已被虛擬機加載的類信息, 常量, 靜態變量, 即使編譯器編譯后的代碼等數據

2.5.2 運行時常量池

運行時常量池是方法區的一部分, 但是 JDK6 之后, 常量池被放入了堆中;

Class 文件中也有常量池部分, 即編譯期生成的各種字面量和符號引用, 這部分將在類加載后進入方法區的運行時常量池中, 此外還會把翻譯出來的直接引用也存儲在運行時常量池中

運行時常量池相對于 Class 文件常量池的另外一個最重要的特征是具備動態性, 即運行期間也可以將新的常量放入池中, 比如 String 的 intern() 方法

String.intern() 作用是: 如果字符串常量池中已經包含一個等于此 String 對象的字符串, 則返回代表池中這個字符串的 String 對象; 否則, 將此 String 對象包含的字符串添加到常量池中, 并且返回此 String 對象的引用

同樣, 收方法區的限制, 當常量池無法再申請到內存時會拋出 OutOfMemoryError

2.5.3 異常情況

OutOfMemoryError : 方法區無法滿足內存分配需求

異常示例:

public class RuntimeConstantPoolOOM {
    public static void main(String[] args) {        List<String> list = new ArrayList<>();        int i = 0;        while (true) {
            list.add(String.valueOf(i++).intern());
        }
    }
}

2.6 直接內存

直接內存不是虛擬機運行時數據區的一部分, 但是也被頻繁使用, 如: 在 JDK1.4 中新加入了 NIO 類, 引入了一種基于通道( Chanel )和緩沖區( Buffer )的 I/O 方式, 它可以使用 Native函數庫直接分配堆外內存, 然后通過一個存儲在 Java 堆中的 DirectByteBuffer 對象作為這塊內存的引用進行操作, 避免了在 Java 堆和 Native 堆中來回復制數據, 提高性能

同樣會產生 OutOfMemoryError

“Java內存區域與內存溢出異常知識講解”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注創新互聯網站,小編將為大家輸出更多高質量的實用文章!

文章題目:Java內存區域與內存溢出異常知識講解
文章分享:http://vcdvsql.cn/article14/gjdoge.html

成都網站建設公司_創新互聯,為您提供電子商務外貿網站建設手機網站建設云服務器商城網站服務器托管

廣告

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

成都app開發公司