집 >운영 및 유지보수 >리눅스 운영 및 유지 관리 >리눅스의 가상 메모리 메커니즘은 무엇입니까
1. 각 프로세스는 자체적으로 독립적인 4G 메모리 공간을 가지며, 각 프로세스의 메모리 공간은 유사한 구조를 가지고 있습니다.
Linux 메모리 관리는 동적 주소 변환 메커니즘, 주 메모리 및 보조 메모리를 사용하여 페이지 관리를 채택하여 새로운 프로세스가 설정되면
자체 메모리 공간을 구축하고 이 프로세스의 데이터, 코드 등이 디스크에서 자체 프로세스 공간으로 복사됩니다.
모두 프로세스 제어 테이블의 task_struct에 의해 기록됩니다. task_struct에 기록된 연결 목록이 있고, 기록에 메모리 공간 할당이 기록됩니다.
이 링크드 리스트를 통해 어떤 주소에 데이터가 있는지, 어떤 주소에 데이터가 없는지, 어떤 주소에 쓰기가 가능한지 기록할 수 있다.
2. 각 프로그램은 완전하고 연속적인 주소 공간을 볼 수 있습니다. 이러한 공간은 물리적 메모리와 직접적인 관련이 없지만 운영 체제는 메모리에 대한 추상적인 개념을 제공합니다.
이를 통해 각 프로세스는 연속적이고 완전한 주소 공간을 가질 수 있습니다. 프로그램이 실행되는 동안 가상 주소에서 물리적 주소로의 변환이 완료됩니다.
우리는 또한 프로세스의 주소 공간이 분할되어 있으며 소위 데이터 세그먼트, 코드 세그먼트, bbs 세그먼트, 힙, 스택 등이 있다는 것을 알고 있습니다. 각 세그먼트에는 특정 역할이 있습니다.
동시에 컴퓨터에는 그다지 많은 메모리가 없습니다(n 프로세스는 n*4G 메모리에 해당해야 함). 프로세스를 생성하려면 디스크의 프로그램 파일을 프로세스에 해당하는 메모리에 복사해야 합니다.
하나의 프로그램이 여러 프로세스에 해당하는 경우 메모리가 낭비됩니다.
3. 각 프로세스의 4G 메모리 공간은 가상 메모리 공간일 뿐입니다. 메모리 공간의 주소에 액세스할 때마다 해당 주소를 실제 물리적 주소로 변환해야 합니다.
각 프로세스는 현재 필요한 가상 메모리 공간만 실제 메모리에 매핑하고 저장합니다. 프로세스는 실제 메모리에 있는 메모리 주소와 그렇지 않은 메모리 주소, 실제 메모리의 위치를 알아야 합니다.
페이지 테이블은 기록되어야 하며, 페이지 테이블의 각 항목은 두 부분으로 나누어집니다. 첫 번째 부분은 해당 페이지가 물리적 메모리에 있는지 여부를 기록합니다. ,
페이지 테이블을 확인하여 해당 데이터가 물리 메모리에 없으면 페이지 누락 예외 처리 프로세스는 프로세스에 필요한 데이터를 디스크에서 물리 메모리로 복사하는 것입니다. 메모리가 가득 찬 경우 , 여유 공간이 없으면 덮어쓸 페이지를 찾습니다. 물론 덮어쓴 페이지가 수정된 경우에는 이 페이지를 디스크에 다시 써야 합니다.
4. 각 프로세스의 메모리 공간은 일관되고 고정되어 있으므로 링커는 데이터의 최종 실제 메모리 주소에 대해 걱정할 필요 없이 실행 파일을 연결할 때 메모리 주소를 설정할 수 있습니다.
이것은 독립된 메모리를 가지고 있습니다. 공간의 이점: 서로 다른 프로세스가 동일한 코드(예: 라이브러리 파일의 코드)를 사용하는 경우 해당 코드의 복사본 하나만 물리적 메모리에 저장할 수 있습니다.
프로그램이 연속적인 메모리 공간을 할당해야 하는 경우 다양한 프로세스는 메모리를 절약하기 위해 자체 가상 메모리만 매핑하면 됩니다. 실제 물리 메모리에 연속된 공간이 필요 없이 가상 메모리 공간에 연속된 공간만 할당하면 되며 조각화(Fragmentation)를 사용할 수 있습니다.
위 내용은 리눅스의 가상 메모리 메커니즘은 무엇입니까의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!