프로세스는 실행 중인 프로그램으로 디스크로부터 메모리에 적재되어 CPU의 할당을 받을 수 있는 것을 말합니다.
운영체제로부터 주소 공간, 파일, 메모리 등을 할당받으며 이것들을 총칭하여 프로세스라고 합니다.
스레드는 프로세스의 실행 단위라고 할 수 있습니다.
스레드는 스레드ID, 프로그램 카운터, 레지스터 집합, 그리고 스택으로 구성됩니다.
멀티 스레드는 하나의 프로세스가 동시에 여러 작업을 수행하는 것을 말합니다.
멀티 스레드를 기반으로 프로그래밍 할 경우에는 멀티 프로세스에 비해 메모리 공간과 시스템 자원 소모를 줄일 수 있습니다.
스레드 간의 통신이 필요한 경우에 별도의 자원을 이용하는 것이 아니라 전역 변수의 공간 또는 동적으로 할당된 공간인 Heap 영역을 이용하여 데이터를 주고받을 수 있습니다.
또한, 스레드의 Context Switching은 프로세스의 Context Switching과 달리 캐시 메모리를 비울 필요가 없기 때문에 더 빠릅니다.
멀티 프로세스를 기반으로 프로그래밍 할 때는 프로세스 간 공유하는 자원이 없기 때문에 동일한 자원에 동시에 접근하는 일이 없습니다.
멀티 스레드는 멀티 프로세스보다 적은 메모리 공간을 차지하고 Context Switching이 빠르지만 오류로 인해 하나의 스레드가 종료되면 전체 스레드가 종료될 수 있다는 문제점과 동기화 문제를 안고 있습니다.
멀티 프로세스는 하나의 프로세스가 죽더라도 다른 프로세스에 영향을 끼치지 않고 정상적으로 수행된다는 장점이 있지만, 멀티 스레드보다 많은 메모리 공간과 CPU 시간을 차지한다는 단점이 존재합니다.
이 두 가지는 동시에 여러 작업을 수행한다는 점에서 같지만 적용해야 하는 시스템에 따라 적합한 동작 방식을 선택하고 적용해야 합니다.