| 프로그램이 실행하기 위한 모든 자원들을 개별적으로 가지고 있어 무겁다. | 개별적으로 분리가 필요한 최소한의 자원들만 가져 경량 process 혹은 LWP(Light Weight Process)라고도 한다. |
| process별로 자체 메모리를 갖는다 | process내의 다른 thread와 메모리를 공유한다. |
| 개별 메모리로 인해 process 간 통신이 느리다. process간 통신을 위해서는 OS에서 제공하는 다양한 통신 기술을 이용해야 한다. | 공유 메모리를 이용한 직접 통신이 가능해 thread 간 통신이 빠르다. |
| Multi process 지원 시스템에서는 process context switching시 이전 process의 메모리 및 스택 정보를 storage에 저장하는 swapping이 발생할 수 있으며, 이는 메모리에 있던 정보를 storage에 옮기거나 storage에 저장된 정보를 메모리에 올리는 작업이 수행되므로 비용이 많이 든다 | thread 간 context 전환은 공유 메모리로 인해 비용이 저렴하다. |
| 구성 요소에 대한 여러 process가 있는 application은 메모리가 부족할 때 더 나은 메모리 활용도를 제공할 수 있다. Application의 비활성 process에 낮은 우선순위를 할당할 수 있다. 그러면 이 유휴 process는 storage로 swapping될 수 있다. | 메모리가 부족한 경우 Multi-threaded application은 메모리 관리를 위한 어떠한 조항도 제공하지 않는다. |