- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
此处在页面#6中说明了分页:
http://www.cs.ucc.ie/~grigoras/CS2506/Lecture_6.pdf
在我的演讲笔记中,但我一生无法理解。我知道这是一种将虚拟地址转换为物理地址的方法。因此,磁盘上的虚拟地址被分成2 ^ k的块。在这之后我真的很困惑。有人可以简单地向我解释一下吗?
最佳答案
如前所述,分页是一种虚拟内存。要回答@John Curtsy提出的问题:它通常与虚拟内存分开讨论,因为还有其他类型的虚拟内存,尽管(到目前为止)分页是最常见的。
分页虚拟内存非常简单:将所有物理内存分成多个块,每个块的大小均相等(尽管实际上选择两种或三种大小是相当普遍的)。使块大小相等使得它们可以互换。
然后您有地址。首先将每个地址分成两部分。一个是页面内的偏移量。通常,您对该部分使用最低有效位。如果使用(比如说)4K页面,则需要12位的偏移量。使用(比如说)32位地址空间,则可以再保留20位。
从那里开始,事情实际上比最初看起来要简单得多。基本上,您将构建一个小的“描述符”来描述内存的每一页。这将具有一个线性地址(客户端应用程序用于寻址该内存的地址),该内存的物理地址以及一个Present位。 (至少通常是)其他一些事情,例如权限,指示该页面中的数据是否可以读取,写入,执行等。
然后,当客户端代码使用一个地址时,CPU首先将与该地址其余部分的页偏移量分解。然后,它将获取其余的线性地址,并浏览页面描述符以查找与该线性地址一起的物理地址。然后,为了寻址物理内存,它使用物理地址的高20位和线性地址的低12位,它们一起形成了实际的物理地址,该地址在处理器引脚上输出并从存储芯片中获取数据。 。
现在,我们进入获得“真实”虚拟内存的部分。当程序使用的内存超过实际可用内存时,操作系统将获取其中一些描述符的数据,并将其写出到磁盘驱动器中。然后,清除该内存页面的“Present”位。内存的物理页面现在已释放,用于其他目的。
当客户端程序尝试引用该内存时,CPU会检查Present位是否已设置。如果不是,则CPU引发异常。发生这种情况时,CPU会像上面那样释放一块物理内存,从磁盘读回当前页面的数据,并用当前所在物理页面的地址填充页面描述符。完成所有这些操作后,它将从异常中返回,并且CPU重新开始执行导致异常开始的指令-除非现在将Present位设置为1,所以可以使用内存。
您可能需要了解一个详细信息:页描述符通常安排在页表中,(重要的部分)对于系统中的每个进程(对于OS内核,通常都有一组单独的页表)本身)。每个进程具有单独的页表意味着每个进程可以使用相同的线性地址集,但是根据需要可以将它们映射到不同的物理地址集。您还可以通过仅创建两个包含相同物理地址的独立页面描述符(每个进程一个)来将同一物理内存映射到多个进程。大多数操作系统都使用此功能,例如,如果您正在运行同一个程序的两个或三个副本,则它实际上在内存中将只有该程序的可执行代码的一个副本-但它将只有两个或三个指向同一代码的页面描述符集,因此它们所有人都可以使用它,而无需为每个代码制作单独的副本。
当然,我正在简化很多工作-已经写了很多关于虚拟内存的完整(通常是相当大的)书籍。机器之间也存在相当大的差异,其中添加了各种装饰,对参数进行了较小的更改(例如,页面是4K还是8K),等等。尽管如此,这至少是对所发生事情的核心的一般了解(并且它仍然处于足够高的水平,可以等效地应用于ARM,x86,MIPS,SPARC等)。
关于memory - 什么是分页?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5971766/
在 ARM 中,内存类型指定为: 正常 设备 强烈有序 在Device type里面,好像这个类型也可以区分 不可共享的设备内存 可共享设备内存 不可共享和可共享设备内存有什么区别?我们如何分别使用这
在 ARM 中,内存类型指定为: 正常 设备 强烈有序 在Device type里面,好像这个类型也可以区分 不可共享的设备内存 可共享设备内存 不可共享和可共享设备内存有什么区别?我们如何分别使用这
This diagram很清楚不同YARN和Spark内存相关设置之间的关系,除了spark.python.worker.memory。 spark.python.worker.memory 如何适应
我正在尝试使用复杂的if-else决策树来实现GLSL片段着色器。不幸的是,着色器编译器很早就失败,并出现“语法错误-内存耗尽”错误。 GLSL中的代码大小或决策树深度是否有任何限制?有什么建议如何克
什么是“标记内存”,它如何帮助减小程序大小? 最佳答案 您可能指的是 tagged union ,或更具体地说是硬件实现,如 LISP 机器中使用的标记架构。基本上是一种存储具有类型信息的数据的方法。
我的内存有问题。我不明白为什么当我的程序长时间运行时 Go 使用越来越多的内存(从不释放它)。 第一次分配后,程序使用了将近 9 MB 的内存。然后在 12 小时后,它开始以指数方式使用更多内存,直到
在 Windows 机器上,MATLAB 用户可以使用 memory或 feature memstats命令。但是,这些都不能在机器上工作,失败如下: >> memory??? Error using
引导 Linux 内核时,可以在 RAM 中加载 initramfs 存档和 DTB 文件,并将这些物理地址指定给内核。例如,使用 U-Boot,您可以执行以下操作: bootz 0x80008000
我正在学习虚拟内存的概念,但是这个问题让我困惑了一段时间。由于大多数现代计算机都使用虚拟内存,因此当程序正在执行时,操作系统应该在 RAM 和磁盘之间将数据分页进出。但为什么我们仍然遇到“内存不足”的
我在 Colab Pro+(使用高 RAM 选项)上运行神经网络时发现了这个问题。 运行时错误:CUDA 内存不足。尝试分配 8.00 GiB(GPU 0;15.90 GiB 总容量;12.04 Gi
当我在任何地方阅读基于操作系统的书籍时,考虑到时间限制和开销很高,从内存和 I\O(子系统)获取数据是昂贵的,这就是为什么在某些硬件制造商中提供一些其他方式来访问它们,如ARM7 some ISAs像
据我所知,ADS v.10 尝试将查询结果保留在内存中,直到它变得非常大。对于 __output 表和临时表也应该如此。当结果变大时,交换声明。 问题是为查询、 worker 等设置了什么内存限制?可
序言 我正在写一个小演示文稿来列出使用 Docker 时的一些“陷阱”,我也遇到了自己的一个问题。 在解释让 Docker 在没有内存限制的情况下运行的危险时,我发现它的行为不像我预期的那样。 我使用
我们有一个 ASP.NET 项目(40 个左右的 Web 表单、50 个表、相当标准的 IO 内容,并尽可能减少),很快需要部署。系统上大约有 100 个并发用户,但任何时候只有大约 20 个用户在使
我在 dotcloud 上使用 redis 内存存储,但尽管 key 已过期,但它的 used_memory 再也不会下降。从 redis-cli 使用 flushdb 或 flushall 不会导致
我使用的是 Xcode 10.2.1 和 macOS Catalina Developer Beta 2。每当我尝试使用内存图调试器时,我都会收到此错误: Memory Graph Debugger:
所以我一直在寻找这个问题的解决方案有一段时间了。我编写了一个程序来从两个单独的文本文件中获取数据,对其进行解析,然后输出到另一个文本文件和一个 ARFF 文件以供 Weka 分析。我遇到的问题是我编写
对不起,我对 erlang 文档中的以下描述不太清楚: erlang:memory() -> [{Type, Size}] with Type: "total" means: "The total a
在查看示例合约时,有时会在带有“内存”的方法中声明数组,有时则不会。有什么区别? 最佳答案 如果没有内存关键字,Solidity会尝试在存储中声明变量。 首席 Solidity 开发者 chriset
我不明白Matlab并行计算工具箱中的parfor cicle是如何与内存一起工作的:我读到它在所有worker之间共享内存(然后我认为每个worker(核心)都可以访问感兴趣的内存位置而无需制作本地
我是一名优秀的程序员,十分优秀!