Microsoft MVP성태의 닷넷 이야기
Java: 13. 자바도 64비트에서 (2GB) OutOfMemoryException 예외가 발생할까? [링크 복사], [링크+제목 복사],
조회: 26875
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 121  122  123  124  125  126  127  128  129  130  131  132  [133]  134  135  ...
NoWriterDateCnt.TitleFile(s)
1822정성태12/3/201428209개발 환경 구성: 252. Xamarin 라이선스 관리 [8]
1821정성태12/1/201435896VS.NET IDE: 96. Visual Studio에서 /* ~ */ 주석을 위한 단축키(매크로)
1820정성태11/23/201423300.NET Framework: 485. Mono Profiler에서 IL 코드 변경이 가능할까? - 두 번째 이야기파일 다운로드1
1819정성태11/22/201423222오류 유형: 264. MSBuild 에러 - warning MSB3052: The parameter to the compiler is invalid,
1818정성태11/22/201426759개발 환경 구성: 251. NUMA 노드 수에 따른 IIS Worker Process(w3wp.exe) 설정 [1]
1817정성태11/22/201429893VS.NET IDE: 95. Macros for Visual Studio 2013 [1]
1816정성태11/20/201424422.NET Framework: 484. Mono Profiler에서 IL 코드 변경이 가능할까?
1815정성태11/18/201422471.NET Framework: 483. 코드로 살펴 보는 ETW의 활성화 시점 [2]
1814정성태11/18/201423969오류 유형: 263. Unable to find the requested .Net Framework Data Provider. It may not be installed.
1813정성태11/18/201425394오류 유형: 262. Build Events에 robocopy 작업이 있는 경우 "VCEnd exited with code 3" 오류 발생
1812정성태11/17/201423746.NET Framework: 482. ETW 자동 생성 코드의 VerificationException 예외 발생
1811정성태11/16/201425234.NET Framework: 481. Mono 내부의 문자열 처리 방식은 UTF-8
1810정성태11/15/201462427.NET Framework: 480. C# - 배치 파일 실행하고 출력 결과를 얻는 방법 [4]
1809정성태11/11/201426949.NET Framework: 479. Mono Profiler를 Unity의 Plugin으로 사용하는 방법
1808정성태11/11/201426908.NET Framework: 478. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 [2]
1807정성태11/10/201433943개발 환경 구성: 250. 서버용 Socket에서 사용하는 포트가 충돌한다면?파일 다운로드1
1806정성태11/10/201429756.NET Framework: 477. SeCreateGlobalPrivilege 특권과 WCF NamedPipe
1805정성태11/5/201426033.NET Framework: 476. Visual Studio에서 Mono용 Profiler 개발 [3]파일 다운로드1
1804정성태11/5/201432303.NET Framework: 475. ETW(Event Tracing for Windows)를 C#에서 사용하는 방법 [9]파일 다운로드1
1803정성태11/4/201422888오류 유형: 261. Windows Server Backup 오류 - Error in backup of E:\$Extend\$RmMetadata\$TxfLog
1802정성태11/4/201426189오류 유형: 260. 이벤트 로그 - Windows Error Reporting / AEAPPINVW8
1801정성태11/4/201431930오류 유형: 259. 이벤트 로그 - Windows Error Reporting / IPX Assertion / KorIME.exe [1]
1800정성태11/4/201422286오류 유형: 258. 이벤트 로그 - Starting a SMART disk polling operation in Automatic mode.
1799정성태11/4/201426506오류 유형: 257. 이벤트 로그 - The WMI Performance Adapter service entered the stopped state.
1798정성태11/4/201435108오류 유형: 256. 이벤트 로그 - The WinHTTP Web Proxy Auto-Discovery Service service entered the stopped state. [1]
1797정성태11/4/201421129오류 유형: 255. 이벤트 로그 - The Adobe Flash Player Update Service service entered the stopped state.
... 121  122  123  124  125  126  127  128  129  130  131  132  [133]  134  135  ...