IT

혼공단 4주차 (2) 프로세스와 스레드 (책 챕터10, 유투브 26강~28강)

BoBooBoo 2023. 2. 7. 00:28
반응형

 

 

목차

Chapter 10. 프로세스와 스레드

10-1. 프로세스 개요

10-2. 프로세스 상태와 계층 구조

10-3. 스레드

+ 기본미션 & 선택미션

 

 

프로세스

  • 실행 중인 프로그램
  • Foreground process : 사용자가 볼 수 있는 공간에서 실행되는 프로세스
  • Background process : 사용자와 직접 상호작용이 가능한 백그라운드 프로세스
  • Daemon 혹은 Service : 사용자와 상호작용하지 않고 정해진 일만 수행하는 프로세스
  • 모든 프로세스틑 실행을 위해 CPU 를 필요로 하지만 CPU 는 제한적임
  • 한정된 시간 (Timer Interrupt) 만큼만 CPU 를 이용하고 다음 차례에게 양보함 #스케쥴링
  • 운영체제는 빠르게 번갈아 수행되는 프로세스들을 관해야하 함

 

프로세스 제어 블록 (PCB, Process Control Block)

  • 프로세스 관련 정보를 저장하는 자료 구조
  • 프로세스를 생성할 때 커널 영역에 생성되고 종료 시 폐기
  • 운영체제는 PCB 를 보고 프로세스를 일목요연하게 관리함

 

PCB 에 담기는 정보들

  • 프로세스는 자신의 실행 차례가 오면 이전까지 사용한 프로세스 상태, CPU 스케줄링 정보, 메모리 정보, 사용한 파일과 입출력 장치 정보를 가짐. 
  • Process ID, PID : 특정 프로세스를 식별하기 위해 부여하는 ID 값
  • 레지스터 값 : 자신의 실행 차례가 오면 이전까지 사용한 레지스터 중간 값을 모두 복원하고 실행을 재개함
  • 프로세스 상태 : 입출력 장치 사용 대기 상태,  CPU 사용 대기 상태, CPU 를 이용 중인 상태 등
  • CPU 스케줄링 정보 : 언제 어떻게 얼마나 CPU 를 할당 받을지
  • 메모리 정보 : 프로세스가 어느 주소에 저장되어 있는지에 대한 정보, 페이지 테이블 정보 (메모리 주소를 알 수 있는 정보)
  • 사용한 파일과 입출력 장치 정보 : 할당된 장치나 사용 중인 파일의 정보

 

Context Swiching

Q. 한 프로세스에서 다른 프로세스로 실행 순서가 넘어가면?

 

기존에 실행되던 프로세스의 중간 정보 (Context) 를 백업하고 다시 실행할 때 복구해서 사용

  • 프로그램 카운터 등 각종 레지스터 값, 메모리 정보, 열었던 파일, 사용한 입출력 장치 등
  • 다음 차례가 왔을 때 실행을 재개하기 위한 정보

 

 

프로세스의 메모리 영역 (코드, 데이터, 힙, 스택 등)

코드 영역 (텍스트 영역)

  • 실행할 수 있는 코드, 기계어로 이루어진 명령어 저장
  • 데이터가 아닌 CPU가 실행할 명령어가 담기기에 쓰기가 금지된 영역 (read-only)
  • 크기가 변하지 않아 정적 할당 영역이라고도 함

 

데이터 영역

  • 잠깐 썼다가 없앨 데이터가 아닌 프로그램이 실행되는 동안 유지할 데이터 저장 (e.g. 전역 변수)
  • 크기가 변하지 않아 정적 할당 영역이라고도 함

 

힙 역영

  • 프로그램을 만드는 사용자인 프로그래머가 직접 할당할 수 있는 저장 공간
  • 관련 내용 : Garbage Collection, Memory Leak, ...

 

스택 영역

  • 데이터가 일시적으로 저장되는 공간
  • 데이터 영역에 담기는 값과 달리 잠깐 쓰다가 말 값들이 저장 (e.g. 매개 변수, 지역 변수)

 

 

힙 영역과 스택 영역의 크기는 가변적이며 일반적으로 힙은 낮은 주소로부터, 스택은 높은 주소로부터 할당됨

 


 

기본 미션

p.304, 확인 문제 1번 ) 다음은 프로세스 상태를 보여주는 프로세스 상태 다이어그램입니다. ① 부터 ⑤ 까지 올바른 상태를 적어 보세요.

 

① = 생성 상태

② = 준비 상태

③ = 실행 상태

④ = 종료 상태

⑤ = 대기 상태

 

선택 미션

Ch.11 (11-2) 준비 큐에 A, B, C, D 순으로 삽입 될 때 선입 선처리, 최단 작업 우선, 라운드 로빈, 우선순위 스케줄링에서 어떤 프로세스로 CPU를 할당 받는지 정리해보기

 

  • 선입 선처리 (FCFS) - 준비 큐에 적재된 순서대로 CPU 할당
  • 최단 작업 우선 (SJF) - CPU 사용 시간이 가장 짧은 프로세스부터 할당
  • 라운드 로빈 (RR) - 정해진 타임슬라이스 만큼 프로세스들에게 CPU를 할당
  • 우선순위 스케줄링 : 프로세스의 우선순위 별로 순차적으로 할당

 

 

반응형