>Java >java지도 시간 >Java 스택 크기를 늘리고 StackOverflowError를 방지하는 방법은 무엇입니까?

Java 스택 크기를 늘리고 StackOverflowError를 방지하는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-25 18:58:13144검색

How to Increase Java Stack Size and Avoid StackOverflowError?

Java 스택 크기를 늘리는 방법(Xss 매개변수)

JVM에서 런타임 스택의 용량을 늘리려면 '-Xss'를 활용하세요. ' 명령줄 플래그를 적절한 값으로 지정합니다. 'TT' 프로그램(1<<15)의 경우 '-Xss4m'이면 충분합니다.

$ javac TT.java
$ java -Xss4m TT

'-X...' 플래그의 구현 종속성

'-X...' 플래그는 구현별로 다릅니다. 제공된 Java 버전에서는 '-Xss' 플래그가 모든 스레드의 스택 크기를 제어합니다.

스레드별 스택 할당

또는 넉넉한 크기를 할당할 수도 있습니다. java.lang.Thread.stackSize() 메소드를 사용하여 스택 크기를 특정 스레드로 조정합니다. 이 접근 방식은 적절한 스택 요구 사항을 가진 스레드의 메모리 낭비를 방지하므로 유리합니다.

스택 요구 사항 결정

프로그램에 필요한 스택 크기를 측정하려면 반복적으로 실행하세요. 'StackOverflowError' 없이 성공적으로 실행될 때까지 스택 크기가 증가합니다. 'TT' 프로그램의 경우 스택 크기는 다음과 같이 결정되었습니다.

-Xss4m: suffices for (1 << 15)
-Xss5m: suffices for (1 << 17)
...
-Xss515m: suffices for (1 << 25)

비결정적 스택 요구 사항 현상

스택 요구 사항은 다음과 같은 요인으로 인해 비결정적 동작을 나타낼 수 있습니다. 가비지 수집 및 JIT 실행 타이밍. 도달한 스택 깊이를 정확하게 계산하려면 아래 답변을 참조하세요(Javassist 사용).

대체 구현

스택 소비가 적은 대체 알고리즘을 고려하세요. 'fact' 함수의 경우 반복 구현을 활용하여 재귀를 방지하고 스택 사용량을 줄일 수 있습니다.

public class TTIterative {
    // ... implementation ...
}

BigInteger 고려 사항

'fact' 함수는 다음을 수행할 수 없습니다. 오버플로로 인해 'long' 데이터 유형을 사용하여 65보다 큰 숫자에 대한 정확한 계승을 계산합니다. 'BigInteger'를 반환하도록 함수를 리팩토링하면 이 문제가 해결되고 더 큰 입력에 대한 정확한 결과를 제공합니다.

위 내용은 Java 스택 크기를 늘리고 StackOverflowError를 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.