第四章 1程序编译连接

1、程序的装入和链接

程序进内存的一般过程:a.编译compiler:编译程序:将用户源代码编译成若干个目标模块。

b.链接link:链接程序:将形成的一组目标模块,及它们需要的库函数链接在一起,形成一个完整的装入模块。

c.装入load:由装入程序将装入模块装入内存,构造PCB,形成进程,开始运行(使用物理地址)。

地址的概念:逻辑地址(相对地址,虚地址)用户的程序经过汇编或编译后形成目标代码,目标代码中的指令是相对地址。一般首地址为0,其余指令中的地址都相对于首地址来编址。不能用逻辑地址在内存中读取信息。

物理地址(绝对地址,实地址)内存中存储单元的地址。物理地址可直接寻址被执行。

地址映射:将用户程序中的逻辑地址转换为运行时由机器直接寻址的内存物理地址的过程。

程序链接、装入过程围绕着地址的处理

程序装入找中的地址处理:

1)绝对装入方式;2)静态可重定位装入方式;3)动态运行时装入方式


绝对装入

绝对装入方式

编译程序生成的“目标代码”就是“装入模块”,逻辑地址直接从某个地址R处增长,装入模块直接装入内存地址R处。

物理地址由谁生成?

一般由编译或汇编程序给出;或由程序员赋予(要求程序员熟悉内存使用情况)

优点:装入过程简单。不需任何地址变换,程序中的逻辑地址与实际内存物理地址完全相同。

缺点:过于依赖硬件结构,只适用早期针对硬件直接编程、单道环境下。


静态可重定位装入

静态可重定位装入方式

地址映射在程序执行之前进行,重定位后物理地址不再改变。

可由专门设计的重定位装配程序完成(软):装入时根据所定位的内存地址去修改每个逻辑地址,添加相应偏移量,重定位为物理地址。

优点:不需硬件支持,可以装入有限的多道程序

缺点:软件装入一次完成,一个程序通常需要占用连续的内存空间,程序装入内存后不能移动。也不易实现共享。


动态运行时(重定位)装入方式

动态运行时(重定位)装入方式

实际运行中往往会需要程序在内存中的各位置移动,即经常需要重定位到不同的物理地址上。这种运行时移动程序要求地址变换要快速,实现时一般依靠硬件地址变换机构——一个重定位寄存器。

程序装入内存时,可多次重定位到不同位置。且可以不立即把装入模块中的相对地址转换为绝对地址,而是把这种地址转换推迟到程序真正要执行时才进行。

更适用于部分装入。


不同的程序链接方式

装入是使用内存的开始,但链接的不同会使内存的使用有差别:

根据链接时间的不同,分成三种:

①静态链接:装入运行前将多个目标模块及所需库函数链接成一个整体,以后不再拆开。

②装入时动态链接:装入内存时,边装入边链接的链接方式。

③运行时动态链接:对某些目标模块的链接,在执行中需要该目标模块时,才对它进行链接。

① 静态链接:

装入运行前,生成可执行文件时进行的。

将多个目标模块及所需库函数链接成一个整体,以后不再拆开。


静态链接

② 装入时动态链接

由一个目标模块开始装入,若又涉及外部模块调用事件,装入程序再找出相应的外部目标模块,并将它装入内存,还要修改目标模块中的相对地址。

比静态链接好在哪里?

(1)静态链接好的程序,修改部分模块后,需重新链接成可装入程序。动态方式则便于修改和更新。

(2)便于实现共享。静态的N个程序都需要一个模块时,需要进行N次拷贝。


装入时动态链接 

③ 运行时动态链接:

装入时动态链接的问题: 许多情况下,事先不知道某应用程序本次运行需要哪些模块,只能全部装入,装入时全部链接在一起,效率低。

办法:有的模块不经常使用就暂时不装入,运行时用到了再装入。(如程序总不出错,就不会用到错误处理模块。)即运行时动态链接:运行时,将对某些模块的链接推迟到执行时才链接装入。

优点:程序运行装入的内容少了,加快了装入过程,而且节省大量的内存空间。


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

推荐阅读更多精彩内容