深入理解计算机系统 第一章

第一章 计算机系统漫游

1.1 信息就是位+上下文

系统中的所有信息,包括磁盘文件,内存中的程序,内存中存放的用户数据以及网络上传送的数据,都是由一串比特表示的。区分不同数据对象的唯一方法是我们读到这些数据对象的上下文。

1.2 程序被其他程序翻译成不同格式

一个程序的生命周期是从一个高级C语言程序开始的,为了能在系统上运行该程序,每条语句都必须被其他程序转换成一系列低级机器语言,然后这些指令按照可执行目标程序的格式打包好,并以二进制文件的形式存储起来。得到可执行目标文件。

这个翻译过程可归为四个阶段,预处理,编译,汇编,链接,四个阶段构成了编译系统。

1.png

预处理阶段

预处理器根据预编译指令,对C程序进行文本替换。得到.i文件。

编译阶段

编译器将.i翻译成.s,得到一个汇编语言程序。C语言和Fortran编译器产生的输出文件都是一样的汇编语言。

汇编阶段

将.s文件翻译成机器语言指令,并打包成可重定位目标程序,把存在目标文件.o中。.o是二进制文件。

链接

C语言头文件中中的函数存在了预编译好的目标文件,因此该阶段将调用的函数合并到我们的.o文件中,得到可执行目标文件。该文件可以被加载到内存中由系统执行。

1.3 了解编译系统如何工作的益处

  1. 优化程序性能

    我们需要了解一些机器代码以及编译器如何将C转换为机器代码的方式。不同循环语句的比较,switch和ifelse的比较等。

  2. 理解链接时出现的错误

  3. 避免安全漏洞,如缓冲区溢出等

1.4 处理器读并解释储存在内存中的指令

当程序被编译完成后,我们可通过shell指令

linux> ./hello

来运行程序

1.4.1 系统的硬件组成

为了理解运行hello程序时发生了什么,我们需要了解系统的硬件组织。

这是一张近期Intel产品族的模型

2.png

总线

贯穿于整个系统的电子管道,携带信息字节并负责在各个部件间传递。总线传输的数是个重要的系统参数。

IO设备

IO设备是系统与外部的联系通道,每个IO设备通过控制器或适配器与IO总线相连。控制器和适配器的差别在于他们的封装方式。控制器是IO设备本身或系统的主印刷电路板,适配器是插在主板插槽上的卡。

主存

主存用来存放程序和数据,由DRAM构成。按字节编址。

处理器

处理器按照指令模型来操作,该模型由指令集架构决定。指定按照严格的顺序执行,并更新PC寄存器。

1.4.2 运行hello程序

shell将hello文件加载到内存中,通过dma技术,文件可以直接从磁盘到内存,不经过cpu。

3.png

hello程序将字符串中的字节从主存复制到寄存器,再从寄存器复制到显示设备,输出到磁盘。

4.png

1.5 高速缓存至关重要

如上的简单示例说明了一个重要问题,计算机会经常进行IO操作。这些开销减慢了程序运行的速度。因此系统设计者的一个重要目标就是使IO操作尽快完成。

处理器与主存之间存在着巨大的速度差距,并且还在一直扩大。针对这种差异,系统设计者采用了更小更快的高速缓冲存储器作为暂时存储。L1高速缓存通常可达数万字节,访问速度几乎和访问寄存器一样快。通过该方案,能让内存操作基本都在缓存中完成,基于程序局部性原理。

5.png

1.6 储存器的层次结构

计算机的各储存部件间形成了层次结构,底层速度快,造价高,容量小,高层相反。通过该层次结构,就可以用高层的价格和容量,达到底层的速度。

6.png

1.7 操作系统管理硬件

当我们执行程序时,程序并没有直接访问计算机硬件,而是通过操作系统提供的服务来访问。我们可以把操作系统看作是应用程序和硬件之间插入的一层软件。

操作系统有两个基本功能:

防止硬件被应用程序滥用,向应用程序提供简单一致的机制来控制硬件设备。操作系统通过几个抽象服务来实现,如进程,虚拟内存,文件等。

7.png

1.8 系统之间利用网络通信

现代系统经常通过网络和其它系统连接到一起,网络可视作一个IO设备,数据流可以通过网络直接发给另一台机器,不经过本地磁盘,也可通过网络直接读取数据到主存中。

1.9 重要主题

1.9.1 Amdahl定律

对系统的某一部分加速时,其对系统整体性能影响取决于该部分的重要性和加速程度。

8.png

由此可知,想要显著加速整个系统,必须提升全系统中相当大部分的速度

1.9.2 并发和并行

  1. 线程级并发

    构建在进程抽象之上,我们能够设计出同时有多个程序执行的系统,这就导致了并发。自20世纪60年代出现时间共享以来,计算机系统就开始有了对并发执行的支持,但只是简单的使任务按时间切换。这种配置称为单处理器系统。

    后来随着多核处理器,超线程的出现,我们广泛使用了多处理器系统,将多个CPU(核)集成到集成电路芯片上,每个核都有自己的L1和L2缓存,而共用L3缓存.

9.png

而超线程技术则允许一个核并行执行多个控制流。在使用超线程的核中,程序计数器核寄存器有多个备份,共用其他资源。

  1. 指令级并行

    在CPU中,使用流水线技术来极大加快指令的执行。如果指令速度快于一周期一条,则可成为超标量处理器。

  2. 单指令,多数据并行

    许多处理器拥有特殊的硬件,允许一条指令产生多个并行的数据操作。如SIMD指令可以并行加法,通常需要在编程时显式声明。

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

推荐阅读更多精彩内容