페이징

- 프로세스의 주소 공간을 고정된 사이즈의 페이지 단위로 나누어 물리적 메모리에 불연속적으로 할당하는 방식

- 메모리는 Frame이라는 고정크기로 분할

- 프로세스는 Page라는 고정크기로 분할

- Page 크기 = Frame 크기

- Page 와 Frame을 대응시키는 page mapping 과정이 필요하여 paging table을 생성해야 함

- 연속적이지 않은 공간도 활용할 수 있기 때문에 외부 단편화 문제 해결

- paging table 에는 각 페이지 번호와 해당 페이지가 할당된 프레임의 시작 물리 주소를 저장

- 프로세스의 크기가 페이지 크기의 배수가 아닐 경우

  마지막 페이지에 내부 단편화가 발생하고 페이지의 크기가 클수록 내부 단편화가 커짐

 

세그멘테이션

- 프로세스를 서로 크기가 다른 논리적인 블록 단위인 세그먼트로 분할하여 메모리에 할당

- 각 세그먼트는 연속적인 공간에 저장

- 세그먼트들의 크기가 서로 다르기 때문에 프로세스가 메모리에 적재될 때 빈 공간을 찾아 할당하는 기법

- 페이징과 마찬가지로 mapping을 위한 segment table 필요

- 프로세스가 필요한 메모리 공간만큼 메모리를 할당해주기 때문에 내부 단편화 문제는 발생하지 않지만, 중간에 메모리를 해제하면 생기는 외부 단편화 문제가 발생

 

 

참고

https://cocoon1787.tistory.com/860

BELATED ARTICLES

more