Microsoft MVP성태의 닷넷 이야기
Java: 13. 자바도 64비트에서 (2GB) OutOfMemoryException 예외가 발생할까? [링크 복사], [링크+제목 복사],
조회: 24051
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

자바도 64비트에서 (2GB) OutOfMemoryException 예외가 발생할까?

전에 닷넷으로 테스트를 해보았었고, 원인을 설명해 드렸는데요.

.NET 64비트 응용 프로그램에서 왜 (2GB) OutOfMemoryException 예외가 발생할까?
; https://www.sysnet.pe.kr/2/0/946

자바도 비슷하게 한번 테스트를 해보았습니다.

import java.util.ArrayList;

public class TestMain {
    public static void main( String[] args )
    {
    
        ArrayList<Long> t = new ArrayList<Long>();
        
        for (long i = 0; i < Long.MAX_VALUE; i ++)
        {
            t.add(i);
        }
        
    }
}

이렇게 하고 실행하니, java.exe 프로세스가 뜨고 약 2GB까지 올라가더니 다음과 같은 오류 메시지를 남기며 프로세스가 종료되었습니다.

D:\...\src>java TestMain
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
        at java.util.Arrays.copyOf(Unknown Source)
        at java.util.Arrays.copyOf(Unknown Source)
        at java.util.ArrayList.ensureCapacity(Unknown Source)
        at java.util.ArrayList.add(Unknown Source)
        at TestMain.main(testmain.java:16)

제가 자바에 대해서는 잘 몰라서, (Heap 제한이 있다고 하길래) 다음과 같이 옵션을 조정해서도 실행해 보았는데, 결과는 동일하게 2GB 근처에서 비정상 종료되었습니다.

java TestMain -vmargs -XX:MaxPermSize=4096m -Xms4096m -Xmx4096m

자바도, JVM 개체 하나가 가질 수 있는 최대 메모리 용량이 2GB로 제한되어 있는 거 아닐까요? 이 글을 읽고 있는 자바 프로그래머들의 덧글을 기대하면서 이번 글은 이걸로 마칩니다. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 6/12/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  [98]  99  100  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11517정성태5/10/201819445.NET Framework: 746. Azure runbook 예제 - 6시간 동안 수행 중인 VM을 중지 [1]파일 다운로드1
11516정성태5/9/201820202.NET Framework: 745. Azure runbook을 PowerShell 또는 C# 코드로 실행하는 방법파일 다운로드1
11515정성태5/9/201822709.NET Framework: 744. C# 6 - Expression bodied function [1]
11514정성태5/3/201820696오류 유형: 466. Bitvise - Error in component session/transport/kexHandler [2]
11513정성태5/3/201827551.NET Framework: 743. C# 언어의 공변성과 반공변성 [9]파일 다운로드2
11512정성태5/2/201819833개발 환경 구성: 375. Azure runbook 실행 시 "Errors", "All Logs"에 오류 메시지가 출력되는 경우
11511정성태5/2/201821484개발 환경 구성: 374. Azure - Runbook 기능 소개
11510정성태4/30/201822330.NET Framework: 742. windbg로 확인하는 Finalizer를 가진 객체의 GC 과정파일 다운로드1
11509정성태4/28/201820726.NET Framework: 741. windbg로 확인하는 객체의 GC 여부
11508정성태4/23/201822346개발 환경 구성: 373. MSBuild를 이용해 프로젝트 배포 후 결과물을 zip 파일로 압축하는 방법파일 다운로드1
11507정성태4/20/201822936개발 환경 구성: 372. MSBuild - 빌드 전/후, 배포 전/후 실행하고 싶은 Task 정의
11506정성태4/20/201827165.NET Framework: 740. C#에서 enum을 boxing 없이 int로 변환하기 - 두 번째 이야기 [7]파일 다운로드1
11505정성태4/19/201819979개발 환경 구성: 371. Azure Web App 확장 예제 - Simple WebSite Extension
11504정성태4/19/201821570오류 유형: 465. Azure Web App 확장 - Extplorer File manager 적용 시 오류
11503정성태4/19/201820604오류 유형: 464. PowerShell - Start-Service 명령 오류 (Service 'xxx' cannot be started)
11502정성태4/17/201822807개발 환경 구성: 370. Azure VM/App Services(Web Apps)에 Let's Encrypt 무료 인증서 적용 방법 [3]
11501정성태4/17/201820030개발 환경 구성: 369. New-AzureRmADServicePrincipal로 생성한 계정의 clientSecret, key 값을 구하는 방법파일 다운로드1
11500정성태4/17/201821007개발 환경 구성: 368. PowerShell로 접근하는 Azure의 Access control 보안과 Azure Active Directory의 계정 관리 서비스
11499정성태4/17/201819655개발 환경 구성: 367. Azure - New-AzureRmADServicePrincipal / New-AzureRmRoleAssignment 명령어
11498정성태4/17/201819744개발 환경 구성: 366. Azure Active Directory(Microsoft Enfra ID)의 사용자 유형 구분 - Guest/Member
11497정성태4/17/201817570개발 환경 구성: 365. Azure 리소스의 액세스 제어(Access control) 별로 사용자에게 권한을 할당하는 방법 [2]
11496정성태4/17/201818086개발 환경 구성: 364. Azure Portal에서 구독(Subscriptions) 메뉴가 보이지 않는 경우
11495정성태4/16/201819917개발 환경 구성: 363. Azure의 Access control 보안과 Azure Active Directory의 계정 관리 서비스
11494정성태4/16/201816240개발 환경 구성: 362. Azure Web Apps(App Services)에 사용자 DNS를 지정하는 방법
11493정성태4/16/201818033개발 환경 구성: 361. Azure Web App(App Service)의 HTTP/2 프로토콜 지원
11492정성태4/13/201816030개발 환경 구성: 360. Azure Active Directory의 사용자 도메인 지정 방법
... 91  92  93  94  95  96  97  [98]  99  100  101  102  103  104  105  ...