[혼공단10기] 운영체제, 프로세스와 스레드, CPU 스케줄링 정리 [혼공컴운 4주차 미션 인증]

2023. 7. 30. 09:50·◈ 공부모임/혼공학습단⏰
728x90


- 혼공컴운 4주차 미션 인증

1. 운영체제

- 운영체제란?

실행할 프로그램에 필요한 자원을 할당하고, 프로그램이 올바르게 실행되도록 돕는 특별한 프로그램
  • 커널 : 운영체제의 핵심 기능을 담당
  • 이중 모드 : CPU가 명령어를 실행하는 모드를 커널 모드와 사용자 모드로 구분하는 방식
  • 시스템 호출 : 운영체제의 서비스를 제공받기 위해 커널 모드로 전환하는 방법
  • 대표적인 운영체제 서비스 : 프로세스 관리, 자원 접근 및 할당, 파일 시스템 관리

2. 프로세스와 스레드

- 프로세스란?

실행 중인 프로그램. 프로세스의 종류에는 포그라운드 프로세스와 백그라운드 프로세스가 있다. 운영체제는 프로세스 제어 블록을 통해 여러 프로세스를 관리한다.
  • 프로세스 상태에는 생성, 준비, 실행, 대기, 종료가 있다.
  • 많은 운영체제는 프로세스가 프로세스를 낳는 프로세스 계층 구조로 프로세스를 관리한다.
  • 프로세스를 생성한 프로세스를 부모 프로세스, 생성된 프롯세스를 자식 프로세스라고 부른다.

- 스레드란?

프로세스 내의 실행 흐름 단위. 여러 프로세스를 동시에 실행하는 것을 멀티프로세스, 여러 스레드로 프로세스를 동시에 실행하는 것을 멀티스레드라고 한다.

- p.304의 확인 문제 1번

p.304의 확인 문제 1번


① 생성 ② 준비 ③ 실행 ④ 종료 ⑤ 대기

3. CPU 스케줄링

CPU 스케줄링은 공정하고 합리적으로 CPU 자원을 배분하는 방법을 의미
(운영체제는 효율적인 스케줄링을 이해 스케줄링 큐를 사용한다.)
  • 준비 큐 : CPU 할당을 기다리는 프로세스들을 위한 큐
  • 대기 큐 : 입출력장치를 기다리는 프로세스들을 위한 큐
  • 선점형 스케줄링 : 프로세스가 이용 중인 자원을 빼앗을 수 있다.
  • 비선점형 스케줄링 : 프로세스가 이용 중인 자원을 빼앗을 수 없다.

- CPU 스케줄링 알고리즘

  • 선입 선처리 스케줄링(FCFS) : 준비 큐에 삽입된 순서대로 CPU를 할당
  • 최단 작업 우선 스케줄링(SJF) : 준비 큐에 삽입된 프로세스들 중 CPU 사용 시간의 길이가 가장 짧은 프로세스부터 CPU를 할당
  • 라운드 로빈 스케줄링 : 정해진 시간만큼만 돌아가며 CPU를 할당
  • 우선순위 스케줄링 : 가장 높은 우선순위를 가진 프로세스에 CPU를 할당
  • 다단계 피드백 큐 스케줄링 : 프로세스들이 큐 사이를 이동할 수 있는 다단계 큐 스케줄링

728x90
'◈ 공부모임/혼공학습단⏰' 카테고리의 다른 글
  • [혼공단10기] 가상 메모리, 연속 메모리 할당 정리 [혼공컴운 6주차 미션 인증]
  • [혼공단10기] 프로세스 동기화, 동기화 기법 정리 [혼공컴운 5주차 미션 인증]
  • [혼공단10기] 메모리와 캐시 메모리, 보조기억장치, 입출력 방법 정리 [혼공컴운 3주차 미션 인증]
  • [혼공단10기] ALU와 제어장치, 레지스터, 명령어 사이클, CPU 성능 향상 기법 정리 [혼공컴운 2주차 미션 인증]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    코딩 테스트
    Java
    백준
    자바스크립트
    html
    백준 티어
    일상
    BOJ
    CSS
    코딩
    Database
    jsp
    꿀팁
    javascript
    spring
    Error Note
    SQL
    Project
    Oracle
    프로그래밍
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[혼공단10기] 운영체제, 프로세스와 스레드, CPU 스케줄링 정리 [혼공컴운 4주차 미션 인증]
상단으로

티스토리툴바