Kotlin/동시성 제어

목표 JVM 프로세스와 멀티 스레드 환경에 대해 이해한다. 공유되는 자원과 공유되지 않는 자원의 차이와 공유되는 자원의 접근 시 주의할점에 대해 이해한다. 개요 앞서 프로세스란 자원을 할당받아 실행되는 프로그램이라고 말했다. 즉, JVM은 하나의 프로세스이다. 하나의 프로세스는 여러 작업 단위를 가질 수 있는데 이 작업 단위를 바로 스레드라고 한다. JVM에서는 Main Thread라 불리는 쓰레드가 있고, 우리가 main() 메서드를 사용해 불리는 것이 바로 Main Thread이다. Main Thread가 종료되면 나머지 Thread 들도 자동으로 종료가 된다. 즉, JVM에서 Main Thread가 살아있는 것은 필수적이다. 하지만, 여러 Thread로 동시에 연산을 할 수 있음에도 Main Thr..
목표 프로그램과 프로세스의 차이에 대해 이해한다. 개요 동시성 제어에서 멀티 스레드 환경이 무엇인지를 이해하기 위해서는 프로그램과 프로세스의 차이에 대해 이해하는 것이 중요하다. 따라서 먼저 프로그램과 프로세스의 차이가 무엇인지 알고 가자. 프로그램이란 명령어들의 조합이다. 우리가 작성하는 소스코드 파일들의 묶음이 바로 프로그램이다. 하지만, 소스코드 파일들을 묶음 만으로는 실행이 불가능하다. 이를 실행하기 위해서는 컴퓨터의 메모리에 올려서 실행되어야 한다. 아래에서는 JVM에서 어떻게 java나 kt파일이 메모리에 올라가 실행되는지를 도식화하였다. 아래 그림2를 살펴보자. JVM은 OS로부터 자원을 할당받아 실행되는 프로세스이다. JVM 프로세스에서 돌아가는 프로그램은 바이트코드의 묶음이다. JVM에서..
Dev.Cho
'Kotlin/동시성 제어' 카테고리의 글 목록 (2 Page)