JAVA/비동기 프로그래밍 15

[Java] 동기화 개념

1. 싱글 쓰레드 vs 멀티 쓰레드 프로세스는 오직 한 개의 쓰레드로만 구성하는 싱글 쓰레드 프로세스와 하나 이상의 쓰레드로 구성하는 멀티 쓰레드 프로세스로 구분할 수 있습니다,. 멀티 쓰레드가 항상 좋은 것은 아니며, 자원을 효율적으로 활용하고 성능을 고려한 후에 적절한 방식을 선택해야 합니다. 현재 시중에 나온 CPU는 대부분 멀티코어를 지원하기 때문에 병렬적 성능 및 동시적 자원을 사용하는 관점에서는 대부분 멀티 쓰레드 기반 프로그래밍이 유리한 것은 맞으나 비동기 논블로킹 프로그래밍 같이 싱글 쓰레드 혹은 적은 쓰레드를 활용하는 것이 좋은 성능 및 응답성을 보여줄 수도 있음 1.1 싱글 쓰레드 장점 context switching으로 인한 딜레이가 없음 동시성 문제없음 자원을 적게 사용 앞서 언급한..

[Java] Java 쓰레드 활용

1. UncaughtExceptionHandler 자바 쓰레드의 run() 메서드는 예외를 던질 수 없기 때문에 예외가 발생할 경우 run() 메서드 내에서만 예외를 처리해야 함 RuntimeException이 발생하더라도 쓰레드 밖에서 예외를 잡고 처리하는 방법 없음 자바에서는 쓰레드가 비정상적으로 종료되었거나 특정한 예외를 쓰레드 외부에서 처리할 수 있도록 UncaughtExceptionHandler 인터페이스 제공 해당 인터페이스를 통해 어떤 원인으로 인해 쓰레드가 종료되었는지 대상 쓰레드와 예외를 파악 가능 코드 부연 설명 정적 메서드인 setDefaultUncaughtExceptionHandler() 메서드를 통해 모든 쓰레드에서 발생하는 uncaughtException에 대해 디폴트로 처리하는..

[Java] Java 쓰레드 기본 API

개요 해당 게시글에 앞서 아래 포스팅을 읽고 오시면 이해하는데 도움이 되실 것입니다. https://jaimemin.tistory.com/2369 [Java] 쓰레드 생성 및 실행 구조 개요해당 게시글에 앞서 아래 포스팅을 읽고 오시면 이해하는데 도움이 되실 것입니다. https://jaimemin.tistory.com/2357 [OS] 운영체제 기초Process vs Thread Process 프로그램의 실제 실행을 의미하며 프로그 jaimemin.tistory.com 1. sleep() 1.1 개요 지정된 시간 동안 현재 쓰레드의 실행을 일시 정지하고 Timed Waiting 상태로 빠졌다가 시간이 지나면 Ready To Run 상태로 전환 native 메서드이기 때문에 OS에 위임하며 시스템 콜을 ..

[Java] 쓰레드 생성 및 실행 구조

개요해당 게시글에 앞서 아래 포스팅을 읽고 오시면 이해하는데 도움이 되실 것입니다. https://jaimemin.tistory.com/2357 [OS] 운영체제 기초Process vs Thread Process 프로그램의 실제 실행을 의미하며 프로그램 파일을 실행함으로써 프로그램 데이터들이 메모리에 올라와 CPU를 할당받고 명령을 수행하고 있는 상태 프로세스는 운영체제로jaimemin.tistory.com 자바 쓰레드 개요 및 생성 방법자바 쓰레드는 JVM에서 User Thread를 생성할 때 Kernel Thread와 1:1로 매핑되어 최종적으로 커널에서 관리됩니다.JVM에서 쓰레드를 생성할 때마다 Java Native Interface(JNI)를 통해 커널 영역을 호출하여 자바 쓰레드와 대응하는 커..

[OS] 운영체제 기초

Process vs Thread Process 프로그램의 실제 실행을 의미하며 프로그램 파일을 실행함으로써 프로그램 데이터들이 메모리에 올라와 CPU를 할당받고 명령을 수행하고 있는 상태 프로세스는 운영체제로부터 자원을 할당받은 최소 작업 단위 OS는 프로세스마다 각각 독립된 메모리 영역을 동적 할당을 받는 stack과 heap 그리고 정적 할당을 받은 data와 code 형식으로 할당 독립된 메모리 영역을 할당해 주기 때문에 프로세스 간 영향을 받지 않고 독립적인 작업 수행 기본적으로 프로세스 간 변수나 자료에 접근할 수 없고 통신 기법을 통해 프로세스 간 통신을 해야 함 stack 메서드 안에서 선언된 지역 변수, 매개변수, 반환 값 등이 저장 함수의 호출과 함께 할당되며 함수의 호출이 완료되면 소멸..