在Java中,正在執行的程式的每個介面、類別、物件、變數和方法都儲存在電腦記憶體的不同位置。堆是運行時儲存變數、方法和類別的值的記憶體區域的一部分。它的分配是動態發生的,並且可以根據應用程式的需求成長或縮小。另一方面,引用變數、方法和類別的名稱儲存在堆疊記憶體區域中。但是,如果由於某種原因未正確處理它們的分配,則可能會導致我們將在本文中討論的記憶體錯誤。
與堆疊相關的錯誤
每當進程啟動時,它都會自動定義固定的堆疊大小。在每個方法呼叫期間,都會在呼叫堆疊上建立一個呼叫幀,並持續到方法呼叫結束為止。當電腦記憶體的堆疊空間中沒有剩餘空間用於新堆疊幀時,我們會遇到 StackOverflowError。
範例 1
以下範例說明了 StackOverflowError
import java.lang.StackOverflowError; public class Overflw { public static void methodA(int n1) { n1++; methodB(n1); } public static void methodB(int n1) { n1++; methodA(n1); } public static void main(String []args) { int n1 = 0; methodA(n1); } }
輸出
Exception in thread "main" java.lang.StackOverflowError at Overflw.methodB(Overflw.java:10) at Overflw.methodA(Overflw.java:6) at Overflw.methodB(Overflw.java:10) at Overflw.methodA(Overflw.java:6) at Overflw.methodB(Overflw.java:10) at Overflw.methodA(Overflw.java:6) at Overflw.methodB(Overflw.java:10)
如您所看到的範例 1 程式碼的輸出,我們收到了 StackOverflowError。在這裡,我們創建了兩個名為「methodA」和「methodB」的參數化使用者定義方法。在主方法中,我們聲明了整型變數“n1”並將其初始化為 0,並使用參數“n1”呼叫“methodA” 。現在,“methodA”調用“methodB”,並增加了“n1”的值。同樣,“methodB”呼叫“methodA”,並且此過程會重複多次。因此,在某些時候,為此程式創建的堆疊大小會耗盡,從而導致以下錯誤。
我們可以採取以下措施來處理StackOverflowError
為重複的方法提供適當的終止條件
減少局部變數或陣列的大小也可能有所幫助。
重構程式碼以避免無限的方法呼叫。
範例 2
現在,借助這個範例,我們將嘗試找到 StackOverflowError 的解決方案 發生在前面的範例中。
public class Overflw { public static void methodA(int n1) { n1++; methodB(n1); } public static void methodB(int n1) { n1++; int n2 = 5; int mult = n1 * n2; System.out.println("Value of n1 and n2 multiplication is: " + mult); } public static void main(String []args) { int n1 = 0; methodA(n1); } }
輸出
Value of n1 and n2 multiplication is: 10
在範例 1 中,程式碼的問題是第 6 行和第 10 行沒有終止。但在上面的範例中,我們給了一條終止程式並列印儲存在「mult」中的值的語句。
與堆相關的錯誤
JVM 的「-Xmx」和「-Xms」兩個屬性決定了 Heap 的大小。此大小會影響值的儲存。當JVM由於堆記憶體部分空間不足而在值分配時遇到問題時,我們會遇到OutOfMemoryError
範例 1
以下範例說明了 OutOfMemoryError。
public class MemoryErr { public static void main(String[] args) { String stAray[] = new String[100 * 100 * 100000]; } }
輸出
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space at MemoryErr.main(MemoryErr.java:3)
在上面的程式碼中,我們分配的大小大於堆大小,因此,我們得到了 OutOfMemoryError
我們可以採取以下措施來處理OutOfMemoryError。
我們可以使用 -Xmx 和 -Xms JVM 選項來增加堆的大小
#使用適合應用程式行為的垃圾收集器也可能有所幫助。
範例 2
以下範例說明如何使用 try 和 catch 區塊處理 OutOfMemoryError。
public class MemoryErr { public static void main(String[] args) { try { String stAray[] = new String[100 * 100 * 100000]; } catch(OutOfMemoryError exp) { System.out.println("Application reached Max size of Heap"); } } }
輸出
Application reached Max size of Heap
結論
本文首先解釋了每個 Java 程式所需的兩個記憶體空間。在後面的部分中,我們討論了與堆疊和堆疊記憶體相關的錯誤
以上是Java中的堆疊和堆疊記憶體錯誤的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文分析了2025年的前四個JavaScript框架(React,Angular,Vue,Susve),比較了它們的性能,可伸縮性和未來前景。 儘管由於強大的社區和生態系統,所有這些都保持占主導地位,但它們的相對人口

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

Node.js 20通過V8發動機改進可顯著提高性能,特別是更快的垃圾收集和I/O。 新功能包括更好的WebSembly支持和精製的調試工具,提高開發人員的生產率和應用速度。

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA

本文介紹了SnakeyAml中的CVE-2022-1471漏洞,這是一個允許遠程代碼執行的關鍵缺陷。 它詳細介紹瞭如何升級春季啟動應用程序到Snakeyaml 1.33或更高版本的降低風險,強調了依賴性更新

本文探討了在黃瓜步驟之間共享數據的方法,比較方案上下文,全局變量,參數傳遞和數據結構。 它強調可維護性的最佳實踐,包括簡潔的上下文使用,描述性

本文使用lambda表達式,流API,方法參考和可選探索將功能編程集成到Java中。 它突出顯示了通過簡潔性和不變性改善代碼可讀性和可維護性等好處


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境