분류 전체보기 420

[JVM 밑바닥까지 파헤치기] 8-1. 바이트코드 실행 엔진: 런타임

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다 가상머신의 실행 엔진은 순수하게 소프트웨어로만 구현됨명령어 집합의 구조와 실행 엔진을 물리적 제약 없이 원하는 대로 만들 수 있음 1. 런타임 스택 프레임 구조메서드가장 기본적인 실행 단위 스택 프레임메서드 호출과 실행을 뒷받침하는 내부 데이터 구조필요한 깊이에 맞게 계산되어 크기가 정해짐실행중인 메서드의 스택 프레임은 맨 위에 있음 지역 변수 테이블매개 변수와 메서드 안에서 정의된 지역변수 저장하나의 변수 슬롯 범위로 변수 하나가 할당될 수 있음인덱스 방식0: this매개 변수들지역 변수들 피연산자 스택타입 크기 단위: 32비트스택 프레임간 공유상부의 지역 변수 테이블이 하부의 피연산자 스택과 공유됨성능 효율 목적 동적 링크메서드에..

Java 2024.12.24

[JVM 밑바닥까지 파헤치기] 7-3. 클래스 로딩 매커니즘: 자바 모듈 시스템

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다1. JPMSJava 9에서 도입된 모듈 시스템자유롭게 설정 가능한 캡슐화 격리 매커니즘모듈 경계를 통해 각 모듈이 서로의 내부를 참조하지 못함기존의 클래스패스에 의존한 안정성 문제를 해결의존성이 실제 존재하는지는 런타임에서 확인되었음컴파일 타임에서 의존성 체크 후 실행 (모듈간의 의존성이 먼저 정의되어 있음) 모듈 정의module-info.java경계 정의 구성requires: 수입하는 모듈 목록exports: 내보내는 모듈 목록uses: 수입하는 서비스 목록provides: 내보내는 서비스 목록open: 내보내는 리플렉션 API 목록 모듈 호환성모듈 패스모듈 시스템에서 모듈이 위치하는 경로기존 클래스패스 방식과 호환되도록 도입된 방..

Java 2024.12.23

[JVM 밑바닥까지 파헤치기] 7-2. 클래스 로딩 매커니즘: 클래스 로더

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다 가상 머신 외부에서 다양한 방식으로 바이트 스트림을 로드하도록 하는 방법 1. 독립적인 공간같은 클래스 로더로 로딩되어야 동치 관계의 클래스라 판단함 2. 부모 위임 모델상위 클래스 로더에게 위임처음부터 클래스 로드 시도 X자신의 차례가 와서야 하위 클래스 로더가 로드 시도 접근 제한자식 클래스 로더는 부모 클래스 로더에서 로드된 클래스를 접근할 수 있음부모 클래스 로더는 자식 클래스 로더에서 로드한 클래스를 접근할 수 없음 구조부트스트랩 클래스 로더JVM 내장JAVA_HOME/lib or -XbootclasspathClass Lib 확장 클래스 로더JVM 외부에 독립적으로 존재java.lang.ClassLoader를 확장 (sun...

Java 2024.12.23

[JVM 밑바닥까지 파헤치기] 7-1. 클래스 로딩 매커니즘: 클래스 로딩 처리 과정

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다 0. 동적 로딩클래스가 필요할 때 클래스가 jvm에 동적으로 로드됨자바는 런타임에 클래스 로딩, 링킹, 초기화가 이루어짐 장점높은 확장성, 유연성런타임에 클래스를 동적으로 교체 가능네트워크나 외부 소스에서 클래스파일을 가져와 쓸 수 있음JSP, OSGi런타입 바인딩 지원 단점성능 떨어짐 1. Loading특징클래스 로더 사용부트스트랩 클래스 로드 (JVM 내장)사용자 클래스 로더로드 방법 재정의 가능: ClassLoader의 findClass() or loadClass() 오버라이딩배열 클래스는 해당 없음JVM이 직접 메모리에 동적으로 생성클래스 로더가 생성 X 과정클래스를 정의하는 바이트 스트림을 가져옴여러 형식 지원ZIP, DB,..

Java 2024.12.23

[JVM 밑바닥까지 파헤치기] 6-2. 클래스 파일 구조: 바이트코드 명령어

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다 1. 바이트코드 명령어길이1바이트 최대 256개의 연산 코드 표현 가능 데이터 타입명령어 자체에 해당 연산에 필요한 데이터의 타입 정보가 포함됨iload: int 타입 데이터 로드istore: int 타입 데이터 스토어 2. 로드지역변수를 피연산자 스택에 로드 3. 스토어피연산자 스택의 연산 결과를 지역변수에 저장 4. 산술 명령어피연산자 스택의 값 두 개를 이용해 특정한 산술 연산을 수행결괏값을 다시 피연산자 스택의 맨 위에 저장 정수int 타입용 명령어만 지원iadd, isub, imul, idiv, irem, ineg, ishl, ior, iand, ixor, iinc, dcmpg 부동 소수점IEEE 754 명세를 엄격히 따름근..

Java 2024.12.22

[JVM 밑바닥까지 파헤치기] 6-1. 클래스 파일 구조: 클래스 파일

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다 1. 클래스 파일하위 호환성을 위해 예전부터 지금까지 기존의 구조를 유지한 채 확장되어왔음하나의 클래스 또는 인터페이스를 정의바이트를 하나의 단위로 하는 이진 스트림 집합체빅 엔디언 방식 2. 의사 구조ClassFile { u4 magic; // 매직 넘버 (0xCAFEBABE) u2 minor_version; // 클래스 파일의 마이너 버전 u2 major_version; // 클래스 파일의 메이저 버전 u2 constant_pool_count; // 상수 풀 항목의 개수 cp_in..

Java 2024.12.22

[JVM 밑바닥까지 파헤치기] 3-5. 가비지 컬렉터와 메모리 할당 전략: 저지연 가비지 컬렉터

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다 1. 성능 지표컬렉터는 최대 두개의 성능지표 달성이 가능함 지연 시간처리량메모리 사용량 2. 셰넌도어현재는 OpenJDK에서만 제공됨힙 크기와 상관없이 일시 정지를 10밀리초 이내에 묶어두는 것이 목표 동시 모으기사용자 스레드는 GC 스레드와 동시에 수행됨 연결 행렬리전 간 참조 관계 기록

Java 2024.12.21

[JVM 밑바닥까지 파헤치기] 3-4. 가비지 컬렉터와 메모리 할당 전략: 클래식 가비지 컬렉터

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다 JDK 7 ~ JDK 11 내의 GC 기술고성능 / 저지연 컬렉터들과 구분됨 1. 구세대시리얼 올드 컬렉터가장 기초적이고 오래된 컬렉터Mark-Compact 알고리즘단일 스레드메모리 사용량이 적음멀티코어 시스템에서 성능이 저하됨 매개변수-XX: +UseSerialGC: 시리얼 올드 컬렉터와 신세대 시리얼 컬렉터가 모두 활성화됨 CMS 컬렉터동시성을 지원하는 최초의 컬렉터GC 스레드와 사용자 스레드가 동시에 실행됨일시 정지 시간을 최소로 줄이는데 집중구세대가 68% 이상 차면 동작함 Mark-Sweep 알고리즘최초 표시 (Stop-The-World): GC 루트에서 직접 참조되는 객체 표시동시 표시: GC 루트에서 도달 가능한 모든 객..

Java 2024.12.21

[JVM 밑바닥까지 파헤치기] 3-3. 가비지 컬렉터와 메모리 할당 전략: 구현

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다 1. 루트 노드 열거GC 루트 노드로부터 참조 체인을 찾는 작업스택 프레임을 비롯하여 정적 변수, 레지스터 등을 포함하여 추적루트 노드를 열거하려면 stop the world를 피할 수 없음 OopMapObject Offset Map각 스레드의 스택에 있는 객체 참조의 위치를 기록하는 맵안전 지점이라는 특정한 위치에만 기록OopMap을 모든 명령어에 생성하지 않음 객체 이동 지원GC에 의해 참조가 변경될 경우, 스레드 스택에 있는 참조가 올바르게 갱신되도록 합니다. 2. 안전안전 지점일시 정지 상태를 트리거하는 지점jvm이 스레드의 상태를 안전하게 분석하고, 참조 관계를 변경하지 않을 것임을 보장 자발적 멈춤플래그 비트 사용각 스레드..

Java 2024.12.21

[JVM 밑바닥까지 파헤치기] 3-2. 가비지 컬렉터와 메모리 할당 전략: 가비지 컬렉션

저우즈밍 님의 "JVM 밑바닥까지 파헤치기" 책을 정리한 포스팅 입니다 1. 세대 단위 컬렉션 이론대부분의 GC들의 근간 이론객체들을 나이에 따라 각기 다른 영역에 할당죽을 운명인 객체들을 한데 모음살아남을 객체를 나이가 있는 곳의 영역에 유지 가설약한 세대 가설대다수 객체는 일찍 죽음메모리 접근 최적화Young Generation을 대상으로 GC를 자주 실행시킴 강한 세대 가설살아남은 횟수가 늘어날수록, 더 오래 살 가능성이 높음메모리 접근 최적화장기 생존하는 객체는 Old Generation로 이동Old Generation를 대상으로 GC를 자주 실행하지 않음 세대 간 참조 가설세대 간 참조의 개수는 같은 세대 안에서의 참조보다 훨씬 적음상호 참조 관계두 객체는 삶과 죽음을 함께하는 경향이 있음결국 ..

Java 2024.12.21