分页式 分段式 段页式实现原理

这篇博客详细介绍了程序地址空间的概念,重点解析了分页式、分段式和段页式存储管理的原理。分页式通过页号和页内偏移将虚拟地址转换为物理地址;分段式使用段表,通过段号和段内偏移定位;段页式结合两者,先通过段号找到页表,再由页号和页内偏移确定物理地址。三种方式各有优劣,分页式效率高但不便于程序管理,分段式利于程序组织,而段页式则提供更精细的管理。
摘要由CSDN通过智能技术生成

在这篇博客中,来详细介绍一下程序地址空间的概念,一开始叫做进程地址空间。在内核当中创建一个进程,会有这个PCB(进程控制块),在这个PCB中,有一个内存指针struct mm_struct mm指向程序地址空间,或者叫做进程地址空间。
那么内核空间在哪里呢?
是在用户空间中,在这里讨论的都是以32位系统为参照的。这样自说很枯燥,上个图.
在这里插入图片描述
在父进程PCB中,内存指针指向虚拟地址空间,但是在系统调用出一个子进程的时候,虚拟地址空间是不会被fork出的。父子进程是抢占式执行的,这就是万恶之源,他们使用了同一个地址空间。这是为什么呢?因为进程虚拟地址空间是认为规定的,不能存储数据,要存储数据需要靠的是介质,也就是物理内存。物理内存里存放的是物理地址,那么逻辑地址会指向物理地址,存储数据时首先改变逻辑地址,然后通过一个叫做页表的结构,在页表这个结构中存放逻辑地址和物理地址,这个fork后也会拷贝给子进程。 所以页表的功能子进程也可以继承。
在这里插入图片描述
在这里插入图片描述
这上面就是基本的实现方式。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值