在这篇博客中,来详细介绍一下程序地址空间的概念,一开始叫做进程地址空间。在内核当中创建一个进程,会有这个PCB(进程控制块),在这个PCB中,有一个内存指针struct mm_struct mm指向程序地址空间,或者叫做进程地址空间。
那么内核空间在哪里呢?
是在用户空间中,在这里讨论的都是以32位系统为参照的。这样自说很枯燥,上个图.
在父进程PCB中,内存指针指向虚拟地址空间,但是在系统调用出一个子进程的时候,虚拟地址空间是不会被fork出的。父子进程是抢占式执行的,这就是万恶之源,他们使用了同一个地址空间。这是为什么呢?因为进程虚拟地址空间是认为规定的,不能存储数据,要存储数据需要靠的是介质,也就是物理内存。物理内存里存放的是物理地址,那么逻辑地址会指向物理地址,存储数据时首先改变逻辑地址,然后通过一个叫做页表的结构,在页表这个结构中存放逻辑地址和物理地址,这个fork后也会拷贝给子进程。 所以页表的功能子进程也可以继承。
这上面就是基本的实现方式。
分页式 分段式 段页式实现原理
最新推荐文章于 2022-07-24 08:02:24 发布
这篇博客详细介绍了程序地址空间的概念,重点解析了分页式、分段式和段页式存储管理的原理。分页式通过页号和页内偏移将虚拟地址转换为物理地址;分段式使用段表,通过段号和段内偏移定位;段页式结合两者,先通过段号找到页表,再由页号和页内偏移确定物理地址。三种方式各有优劣,分页式效率高但不便于程序管理,分段式利于程序组织,而段页式则提供更精细的管理。
摘要由CSDN通过智能技术生成