메모리 관리 배경
- 각각의 프로세스는 독립된 메모리 공간을 갖고, OS 혹은 다른 프로세스의 메모리 공간에 접근할 수 없는 제한이 걸려 있다. 단지, OS만이 OS 메모리 영역과 사용자 메모리 영역에 대한 접근의 제약이 없다.
- Swapping : 메모리의 관리를 위해 사용되는 기법. 표준 Swapping 방식으로는 라운드로빈과 같은 스케줄링의 다중 프로그래밍 환경에서 CPU 할당 시간이 긑난 프로세스의 메모리를 보조기억장치로 내보내고 다른 프로세스의 메모리를 불러 들일 수 있다.
단편화(Fragmentation) : 프로세스들이 메모리에 적재되고 제거되는 일이 반복되다 보면, 프로세스들이 차지하는 메모리 틈 사이에 사용하지 못할 만큼의 작은 자유공간들이 늘어나게 되는데, 이것이 단편화 이다. 단편화는 2가지 종류로 나뉜다.
페이징(Paging)
- 하나의 프로세스가 사용하는 메모리 공간이 연속적이어야 한다는 제약을 없애는 메모리 관리 방법이다. 외부 단편화와 압축 작업을 해소 하기 위해 생긴 방법론으로, 물리 메모리는 Frame 이라는 고정크기로 분리 되어 있고, 논리 메모리(프로세스가 점유하는)는 Page라 불리는 고정크기의 블록으로 분리된다.(페이지 교체 알고리즘에 들어가는 페이지)
- 페이징 기법을 사용함으로써 논리메모리가 물리 메모리에 저장 될 때, 연속되어 저장될 필요가 없고, 물리 메모리의 남는 프레임에 적절히 배치됨으로써 외부 단편화를 해결할 수 있다.
- 하나의 프로세스가 사용하는 공간은 여러개의 페이지로 나뉘어서 관리되고(논리메모리에서), 개별 페이지는 순서에 상관없이 물리메모리에 있는 프레임에 Mapping 되어 저장된다고 볼 수 있다.
세그멘테이션(Segmentation)
- 페이징 에서처럼 논리 메모리와 물리 메모리를 같은 크기의 블록이 아닌, 서로 다른 크기의 논리적 단위인 세그먼트로 분할하여 사용자가 두 개의 주소로 지정(세그먼트번호+ 변위)
세그먼트 테이블에는 각 세그먼트의 기준(세그먼트의 시작 물리주소와) 변위(세그먼트의 길이)를 저장.