在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.stackoverflowerrorat 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 spaceat 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中的堆和栈内存错误的详细内容。