운영 체제-파일 시스템
파일
파일은 자기 디스크, 자기 테이프 및 광 디스크와 같은 보조 저장소에 기록되는 명명 된 관련 정보 모음입니다. 일반적으로 파일은 파일 작성자와 사용자가 의미를 정의하는 일련의 비트, 바이트, 행 또는 레코드입니다.
파일 구조
파일 구조는 운영 체제가 이해할 수있는 필수 형식을 따라야합니다.
파일은 유형에 따라 특정 구조가 정의되어 있습니다.
텍스트 파일은 줄로 구성된 일련의 문자입니다.
소스 파일은 일련의 절차 및 기능입니다.
오브젝트 파일은 기계가 이해할 수있는 블록으로 구성된 일련의 바이트입니다.
운영 체제가 다른 파일 구조를 정의 할 때 이러한 파일 구조를 지원하는 코드도 포함합니다. Unix, MS-DOS는 최소 파일 구조 수를 지원합니다.
파일 유형
파일 유형은 텍스트 파일 소스 파일 및 이진 파일 등과 같은 다양한 유형의 파일을 구별하는 운영 체제의 기능을 나타냅니다. 많은 운영 체제는 많은 유형의 파일을 지원합니다. MS-DOS 및 UNIX와 같은 운영 체제에는 다음과 같은 유형의 파일이 있습니다.
일반 파일
- 사용자 정보가 포함 된 파일입니다.
- 여기에는 텍스트, 데이터베이스 또는 실행 프로그램이있을 수 있습니다.
- 사용자는 전체 파일의 추가, 수정, 삭제 또는 제거와 같은 다양한 작업을 파일에 적용 할 수 있습니다.
디렉토리 파일
- 이러한 파일에는 파일 이름 목록 및 이러한 파일과 관련된 기타 정보가 포함되어 있습니다.
특수 파일
- 이러한 파일을 장치 파일이라고도합니다.
- 이러한 파일은 디스크, 터미널, 프린터, 네트워크, 테이프 드라이브 등과 같은 물리적 장치를 나타냅니다.
이 파일은 두 가지 유형이 있습니다.
Character special files − 데이터는 단말기 또는 프린터의 경우와 같이 문자별로 처리됩니다.
Block special files − 데이터는 디스크와 테이프의 경우처럼 블록 단위로 처리됩니다.
파일 액세스 메커니즘
파일 액세스 메커니즘은 파일 레코드에 액세스 할 수있는 방식을 나타냅니다. 파일에 액세스하는 방법에는 여러 가지가 있습니다.
- 순차 액세스
- 직접 / 무작위 액세스
- 인덱스 된 순차 액세스
순차 액세스
순차 액세스는 레코드가 어떤 순서로 액세스되는 것입니다. 즉, 파일의 정보가 순서대로 한 레코드 씩 처리됩니다. 이 액세스 방법은 가장 원시적 인 방법입니다. 예 : 컴파일러는 일반적으로 이러한 방식으로 파일에 액세스합니다.
직접 / 무작위 액세스
랜덤 액세스 파일 구성은 레코드에 직접 액세스하여 제공합니다.
각 레코드는 읽기 또는 쓰기를 위해 직접 액세스 할 수있는 도움으로 파일에 고유 한 주소를 가지고 있습니다.
레코드는 파일 내에서 어떤 순서로도 될 필요가 없으며 저장 매체의 인접한 위치에있을 필요도 없습니다.
인덱스 된 순차 액세스
- 이 메커니즘은 순차 액세스를 기반으로 구축됩니다.
- 다양한 블록에 대한 포인터를 포함하는 각 파일에 대해 인덱스가 생성됩니다.
- 인덱스는 순차적으로 검색되며 포인터는 파일에 직접 액세스하는 데 사용됩니다.
공간 할당
파일은 운영 체제에 의해 할당 된 디스크 공간입니다. 운영 체제는 파일에 디스크 공간을 할당하는 세 가지 주요 방법에 따라 배포됩니다.
- 연속 할당
- 연결된 할당
- 인덱싱 된 할당
연속 할당
- 각 파일은 디스크에서 연속 된 주소 공간을 차지합니다.
- 할당 된 디스크 주소는 선형 순서입니다.
- 구현하기 쉽습니다.
- 외부 조각화는 이러한 유형의 할당 기술에서 중요한 문제입니다.
연결된 할당
- 각 파일에는 디스크 블록에 대한 링크 목록이 있습니다.
- 디렉토리에는 파일의 첫 번째 블록에 대한 링크 / 포인터가 있습니다.
- 외부 조각화 없음
- 순차 액세스 파일에서 효과적으로 사용됩니다.
- 직접 액세스 파일의 경우 비효율적입니다.
인덱싱 된 할당
- 연속 및 링크 할당 문제에 대한 솔루션을 제공합니다.
- 파일에 대한 모든 포인터가있는 인덱스 블록이 생성됩니다.
- 각 파일에는 파일이 차지하는 디스크 공간의 주소를 저장하는 자체 인덱스 블록이 있습니다.
- 디렉토리에는 파일의 인덱스 블록 주소가 포함됩니다.