进程和内存的桥梁——页表技术(x86-64Linux下)

其实这篇文章是printf("%d%d%d",i++,i++,i++)的后续。

需要注意的名词:

地址空间和内存空间

序:

我之前在写完printf函数传参之后,所有的技术层面全在操作系统给我们提供的进程抽象之上,但是,作为一个决定挖坑到底的C程序员,我们继续讨论我们关于“内存”这个神坑。

下面是x86-64Linux操作系统给我们提供的,进程(逻辑)地址空间:

图片发自CSAPP

这个图很经典,刚入坑的朋友可以留个心眼,入坑已久的,不用我多说,自然是倒着也能画出来了。

这个图是结果,我们要找的是它的根,但是我们在下面的讨论,并不以x86-64Linux内核真正的内存映射方式为例,而是仅仅从分页技术的角度去讨论。至于原因,很简单我们是来填坑的,一旦使用了更大的技术,那么我们最终填的坑还不如挖的坑多,所以我们的目标很明确——填小坑。

1、对于内存:我们将内存抽象成一个连续的数组空间(关于内存的层次存储结构的坑,我在之后会填上)。

2、对于进程:由序中进程地址空间的结果可以知道,最终我们的操作系统给内存形成了一个连续的地址空间。

我们的最终结果是把内存和进程联系起来,当然,还有很多其他的引导思路的方式(重定位——静态重定位、静态重定位;对换技术;分区法)。当然我这里是引述的某本我觉得还行的书籍上的内容,我自己还没有形成体系。

呃呃呃,又扯远了。对了,上面的坑,我不负责填。

页表——内存和进程的桥梁

既然是桥梁,当然是这头连着进程,那头牵着内存。放下大图:

“喏,我们的桥就是这个样子”

1、桥梁存在的目的:

方便一个进程使用不连续的(物理)内存空间,想象一下,在内存不足的情况下,如果每个进程都使用连续的内存空间,那么我们的内存一次只能加载少量的进程,那么将消耗更多的时间从硬盘加载进程到内存,而在加载的时间我们的CPU极有可能处于空闲状态,那么我们的程序运行上就感觉很慢,客户体验极差。

我来翻译一下桥梁是怎么连接内存和进程的:

2、逻辑地址空间分页:

我们把进程最终的地址空间划分成相等的若干部分,我们称每一个部分为一。每页都有一个地址编号,我们称为页号。且从0开始依次编排,如0,1,2,3...

3、内存空间分块:

我们把内存等分成与一个页相等的若干部分,每个部分称为内存块。同样,对他们进行编号,块号从0开始依次编排:0#块,1块,2#块,3#块...


页或块的大小是由硬件(系统)确定的,它一般被选择为2的若干次幂。例如,IBM AS/400规定的页面大小为512B,而Intel 80836的页面大小为4KB(即4096B)。所以不同的机器页面大小有所不同。

我们现在得到了几个零散的概念,我在这里再重新梳理一遍:

进程空间的页,内存空间的块,桥梁。

我们的空间页和内存块都是一段绝对连续的线性字节数组,我们要把空间页和内存块连接起来,现在猜测,有一种可能的方式:页表的任一项的一段保存某一空间页的首地址,另一段保存块的首地址。好像没有什么毛病,对吧。但是,这种方式并不利于我们的数据寻址。为什么不利于,这个坑,我也不填。



4、而实际上的联系

我们并不是在页表的每一项保存页和块的首地址,而是页号和页内地址

例如:我们的进程中有一条代码的指令是:LOAD 1,500,它实现把500号单元的数据装到寄存器1中去。这里的500还是我们程序被编译好之后的可重定位地址,还是相对地址。我们首先从地址A(这里是500),由分页地址映像硬件自动得到我们的页表项内容:页号和块号桥(p,d)。然后以页号p为索引去检索页表,得到我们的块号f,然后由块号f和页内地址d在内存空间中进行数据检索。下面是详细图:

每个作者有不同的理解方式,这是某本书原作者的内容

经过上述的步骤,我们的进程地址空间和内存空间就形成了一个良好的联系。再啰嗦一句,上面我只提到数据寻址,其实我们往内存中保存数据时就是这种方式,所以才能有我们数据寻址的结果。

页号p和页内地址d的求值方式


还是从某书的照片,我太懒了,直接看图吧
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,988评论 25 707
  • 一.管道机制(pipe) 1.Linux的fork操作 在计算机领域中,尤其是Unix及类Unix系统操作系统中,...
    Geeks_Liu阅读 3,686评论 1 9
  • 昨天给李晓发了我穿的新买的衣服的照片,问他美不?他说,不美,只是人美了,穿什么都好看。有觉悟,我也是这么觉得的。你...
    范范不适合饭饭阅读 242评论 3 0
  • 00 我是一个智脑。 确切来说,我是由一个智能芯片而进化出来的人格。 如果你还不明白,那么再进一步。按照教科书上的...
    殊婴阅读 510评论 1 4
  • 刚刚修改好论文,洗漱的同时想着今天一直想写的话题。可作了几番思想斗争,结果竟是无内容可写。索性顺其自然,就回忆回忆...
    咚2咯咯阅读 286评论 1 3