- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是学生的初学者:) 我正在研究英特尔架构,
我正在研究内存管理,例如分段和分页。
我正在阅读英特尔的手册,了解英特尔的架构非常好。
但是我仍然对一些基本的东西感到好奇。
为什么在 64 位长模式下,所有段寄存器都将变为位 0?
为什么系统不再使用段寄存器?
因为系统的 64 位大小(例如 GP 寄存器)足以一次包含那些逻辑地址?
保护在 64 位模式下是否正常工作?
我试图找到 64 位寻址,但在 Google 中找不到。也许我的搜索技巧很差,或者我可能需要一些特定的先前知识才能在谷歌中搜索。
因此我想知道为什么 16 位段寄存器不会在 64 位模式下使用,
以及保护如何在 64 位模式下正常工作。
谢谢!
最佳答案
从某种意义上说,当您使用通用寄存器执行数组(“索引”)类型寻址时,您所做的基本上与段寄存器相同。在 糟糕的过去在 8 位和 16 位编程中,许多应用程序需要比 16 位地址所能达到的更多的数据(有时还有更多的代码)。
许多 CPU 通过拥有比 16 位地址所能达到的更大的可寻址内存空间来解决这个问题,并通过“段寄存器”或类似的方式使这些内存区域可访问。程序会将“段寄存器”中的地址设置为高于(65536 字节)16 位地址空间的地址。然后在执行某些指令时,它们会将指令指定的地址添加到适当的(或指定的)“段寄存器”中,以读取超出 16 位地址或 16 位偏移量范围的数据(或代码)。
然而,今天的情况却相反!
为何如此?今天,一个 64 位 CPU 可以寻址超过(不少于)所有可寻址内存空间。今天的大多数 64 位 CPU 都可以处理 40 位到 48 位的物理内存。确实,没有什么可以阻止他们寻址完整的 64 位内存空间,但他们知道没有人(除了 NSA)能负担得起那么多 RAM,此外,将那么多 RAM 卡在 CPU 总线上会导调用容负载下降,并减慢 CPU 芯片外的所有内存访问。
因此,目前这一代主流 CPU 可以处理 40 位到 48 位的内存空间,超过了市场想象中的 99.999%。请注意,32 位是 4 GB(今天有些人确实超过了 2、4、8、16 倍),但即使是 40 位也可以处理 256 * 4GB == 1024GB == 1TB。虽然今天 64GB 的 RAM 是合理的,在极端情况下甚至可能是 256GB,但 1024GB 只是没有必要,除了可能 0.001% 的应用程序,并且无法启动。
如果你属于那个 0.001% 的类别,只需购买一个处理 48 位物理内存的 CPU,你说的是 256TB ......这目前是不切实际的,因为它会大量加载内存总线电容(甚至可能到内存总线完全停止工作的程度)。
重点是这个。当使用普通 64 位寄存器的普通寻址模式已经可以寻址比计算机可以容纳的内存多得多的内存时,添加段寄存器的传统理由就消失了。
这并不意味着人们无法在 64 位 CPU 中找到段寄存器的有用用途。他们可以。几种可能性是显而易见的。但是,对于 64 位通用寄存器和 64 位地址空间,没有什么是通用寄存器无法做到的,而段寄存器可以做到。通用寄存器有很多用途,而段寄存器没有。因此,如果有人计划向现代 64 位 CPU 添加更多寄存器,他们会添加通用寄存器(可以做“任何事情”),而不是添加用途非常有限的“段寄存器”。
他们确实有。您可能已经注意到,AMD 和 Intel 不断向 SIMD 寄存器文件添加更多 [sorta] 通用寄存器,而 AMD 在设计其 64 位 x86_64 CPU(英特尔复制)。
关于memory-management - 为什么 64 位模式(长模式)不使用段寄存器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21165678/
I have created a hybrid activation and then setup an ssm agent on my on-premise windows system.我创
我对 python/django 编程很陌生,因为我没有编程背景。我正在在线上课,我只想确切地知道 manage.py 文件的作用。我试过用谷歌搜索它,但除了在 django-admin.py 周围放
我的 DependancyInject 存在结构问题。 情况 我正在为基于体素的游戏创建服务器;它是完全调制的,但相关模块有以下3个。 NetworkModule(发送和接收数据包)WorldModu
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。 Improve thi
上 Docker正在编写的网站: The MANAGER STATUS column shows node participation in the Raft consensus: No value
我正在尝试使用发布管理作为构建版本的工具,但我很难理解码件、工具和操作之间的真正区别。有人可以分解这三个概念之间的差异以及它们如何相互配合吗? 最佳答案 由于它适用于基于代理的版本: 工具旨在提供自定
当尝试在远程环境中在 pycharm 中执行“run manage.py Task...”时,出现以下错误: ssh://vagrant@127.0.0.1:2222/home/vagrant/.vi
在过去的 48 小时里,我一直在努力解决这个问题,这让我发疯了。 我的 SDK Manager.exe 闪烁一个 cmd 屏幕并在不到一秒内关闭。 经过多方搜索,我终于在调整android.bat并以
我在 this tutorial 之后创建了以下自定义管理命令. from django.core.management.base import BaseCommand, CommandError f
我在一家拥有 2,500 多名员工和同样多的 Android 智能手机的非营利组织工作。 近年来,我们测试了许多 EMM 产品。尽管我们只需要一些非常基本的功能,除了一两个特殊功能,但没有一个能真正赢
我已经在我的网站上安装了 Google 标签管理器,但自从新版本的 Google 标签管理器以来,我无法使用预览选项。每次我点击它时,我都会看到我的网站页面打开,但随后出现以下错误:“Tag Assi
我是 django 的新手,并创建了一个与教程中描述的民意调查网站没有太大区别的应用程序。 在网站上我得到: Exception Type: TemplateSyntaxError Exception
https://cloud.google.com/deployment-manager/docs/configuration/templates/create-basic-template 我可以像这
我们正在使用 Microsoft 的发布管理将我们的 Web 应用程序部署到我们的测试环境 (QA)。它是一个直接的 MVC.Net Web 应用程序。我们的构建生成一个 web 部署包,我们有一个命
我想将 python manage.py 缩短为 ./manage.py。 这可能很简单,但我找不到答案。我在有关 django 的问题的答案之一中看到了一步一步的方法,但我没有记住。尝试在 stac
我想将 python manage.py 缩短为 ./manage.py。 这可能很简单,但我找不到答案。我在有关 django 的问题的答案之一中看到了一步一步的方法,但我没有记住。尝试在 stac
我正在使用安装了 SQL Server Data Tools 的 VS 2012。我有一个 ADO NET 源,它使用 .Net Providers\MySQL 数据提供程序,并试图将一些数据推送到
根据我从文档中阅读的内容 https://developer.android.com/topic/libraries/architecture/workmanager , 它说: The task i
这两个类显然是相关的。 SupportFragmentManager 是否用于使用 FragmentTransaction 生成的 Fragments,而“常规”FragmentManager 专门用
我有一个桌子经理(经理ID、姓名、地址、城市、电话)。如果多个经理来自同一城市,我必须显示城市、姓名和电话详细信息。我的代码是:。但这向我展示了第一行中的一个错误,即“不是按表达式分组”。请救救我!
我是一名优秀的程序员,十分优秀!