- 컴퓨터 하드웨어 바로 위에 설치되어 사용자 및 다른 모든 소프트웨어오 하드웨어를 연결하는 소프트웨어 계층
- 협의의 운영체제(커널) → 전공자가 바라보는 OS
- 운영체제의 핵심부분으로 메모리에 상주하는 부분
- 광의의 운영체제
- 커널 뿐 아니라 각종 주변 시스템 유틸리티를 포함한 개념
- 프로세서, 기억장치, 입출려 장치 등의 효율적 관리
- (특정 사용자나 프로그램이 너무 차별을 당해서 불이익이 당하지 않도록) 사용자간의 형평성있는 자원 분배 (형평성)
- 주어진 자원으로 최대한의 성능을 내도록 (효율성)
- 사용자 및 운영체제 자신의 보호
- 프로세스, 파일, 메시지 등을 관리(운영체제는 하드웨어 자원뿐 아니라 소프트웨어 자원도 관리함)
- 단일 작업(single tasking) : 한번에 하나의 작업만 처리 ex) MS-DOS 프롬프트 상에서는 한 명령의 수행을 끝내기 전에 다른 명령을 수행시킬 수 없음
- 다중 작업(multi tasking) : 동시에 두 개 이상의 작업 처리, 현대의 OS ex) UNIX, MS Windows 등에서는 한 명령의 수행이 끝낙 전ㅇ 다른 명령이나 프로그램을 수행할 수 있음
- 단일 사용자(single user) ex) MS-DOS, MS Windows
- 다중 사용자(multi user) ex) UNIX, NT server
- 일괄 처리(batch processing)
- 작업 요청의 일정량 모아서 한꺼번에 처리
- 작업이 완전 종료될 때까지 기다려야 함
- 시분할(time sharing)
- 여러 작업을 수행할 때 컴퓨터 처리 능력을 일정한 시간 단위로 분할하여 사용
- 일괄 처리 시스템에 비해 짧은 응답시간을 가짐 ex) UNIX
- interactive 방식
- 사람이 느끼기에 빠르면서 동시에 주어진 자원을 최대한 활용하는 것이 목적으로, 사람에 특화된 시스템 → 일반적인 범용 컴퓨터에서 사용하는 시스템
- 실시간(Realtime OS)
- 정해진 시간 안에 어떠한 일이 반드시 종료됨이 보장되어야하는 실시간 시스템을 위한 OS
- 정확한 시간에 종료되어야하는 정교화된 시스템 ex) 원자로/공장 제어, 미사일 제어, 반도체 장비, 로봇 제어
-
Multitasking
-
Multiprogramming
-
Time sharing
-
Multiprocess
-
구분
- 위의 용어들은 컴퓨터에서 여러 작업을 동시에 수행하는 것을 뜻한다.
- Multiprogramming은 여러 프로그램이 메모리에 올라가 있음을 강조
- Time Sharing은 CPU의 시간을 분할하여 나누어 쓴다는 의미를 강조
- Multiprocessor ⭐️ : 하나의 컴퓨터에 CPU(processor)가 여러 개 붙어 있음을 의미, 위 3가지 용어와 하드웨어적으로 다름
- 유닉스(UNIX)
- 코드의 대부분을 C언어로 작성
- 높은 이식성
- 최소한의 커널 구조
- 복잡한 시스템에 맞게 확장 용이
- 소스 코드 공개
- 프로그램 개발에 용이
- 다양한 버전
- System V, FreeBSD, SunOS, Solaris,
- Linux
- DOS(Disk Operating System)
- MS사에서 1981년 IBM-PC를 위해 개발
- 단일 사용자용 운영체제, 메모리 관리 능력의 한계(주 기억장치:640KB)
- MS Windows
- MS사의 다중 작업용 GUI 기반 운영체제
- Plug and Play, 네트워크 환경 강화
- DOS용 응용 프로그램과 호환성 제공
- 불안정성
- 풍부한 지원 소프트웨어
- Handheld device를 위한 OS
- PalmOS, Pocket PC(WinCE), Tiny OS