Read-程序是怎样跑起来的

程序是怎样跑起来的

作者:矢泽久雄[日]
译者:李逢俊

  本文为对《程序是怎样跑起来的》一书内容的整理和概括,部分图片,文字摘选自书籍,如有任何侵权行为请联系作者第一时间删除,谢谢。


对程序员来说CPU是什么


CPU的内部结构解析

  CPU(Central Processing Unit)职责: 解释运行转换成机器语言的内容。

程序运行流程示例:

  1. 用C语言等高级语言编写程序。
  2. 将程序编译后转换成机器语言的EXE文件。
  3. 程序运行时,在内存中生成EXE文件的副本。
  4. CPU解释并执行程序内容。

CPU内部组成:寄存器(20~100个),控制器,运算器,时钟(电流信号相互连通)。

寄存器: 暂存指令,数据等处理对象。
        一个CPU内部会有20~100个寄存器。
控制器: 把内存上的指令,数据等读入寄存器,并根据指令的结果来控制整个计算机。
时钟:   发出CPU开始计时的时钟信号(clock puzzle,频率越高CPU运行速度越快)。

    CPU内存是由许多晶体管组成的电子部件,通常称为:IC(Integrated Circuit,集成电路)。
    内存(main memory,简称主存):主存通过控制芯片等与CPU相连,主要负责储存指令数据。储存的内容随计算机的关闭而自动清除。通常使用DRAM(Dynamic Random Access Memory,动态随机存取储存器)芯片。

CPU是寄存器的集合体

程序是把寄存器作为对象来描述的。

  • 高级语言:使用类似人类的语言的语法来记叙的编程语言的总和。如BASIC,C,C++,Java,Pascal,FORTRAN等。
  • 汇编语言(assembly):采用助记符(memonic)来编写程序,每一个原本是电气信号的机器语言指令都会有一个对应的助记符,助记符常为指令功能的单词,如mov和add分别是数据的储存(move)和相加(addtion)的简写。
  • 机器语言:CPU能够直接解释和执行的语言。(数字0和1的集合)

    通常,将汇编语言编写的程序转化成机器语言的过程称为汇编;反之,机器语言程序转换成汇编语言程序的过程称为反汇编
    把汇编语言转换成机器语言的程序称为汇编器(assembler)。
    把高级语言转换成机器语言的程序称为编译器(compiler)。

/* 汇编语言编写的程序事例  */
mov eax, dword ptr [ebp-8]          //把数值从内存复制到exa
add eax, dword ptr [ebp-0Ch]        //exa的数值和内存的数值相加
mov dword ptr [ebp-4], exa          //把exa的数值(上一次相加的结果)储存在内存中

    高级语言编写的程序在编译后转换成机器语言,然后通过CPU内部的寄存器来处理。
    寄存器中储存的内容既可以是指令也可以是数据。数据分为“用于运算的数值”“表示内存地址的数值”
     8种寄存器的主要种类和功能 如下表:

种类 功能
累加寄存器( accumlulator register ) 储存执行运算后的数据和运算后的数据
标志寄存器( flag register ) 储存运算处理后的CPU状态
程序计数器( program counter ) 储存下一条指令所在的内存的地址
基址寄存器( base register ) 储存数据内存的起始地址
变址寄存器( index register ) 储存基址寄存器的相对地址
通用寄存器( general purpose register ) 储存任意数据
指令寄存器( instruction register ) 储存指令。CPU内部使用,程序员无法通过程序对该寄存器进行读写操作
栈寄存器( stack register ) 储存栈区域的起始地址
寄存器数量 寄存器种类
仅有一个 程序计数器,标志寄存器,累加寄存器
含有多个 基址寄存器,变址寄存器,通用寄存器

CPU是寄存器的集合体

决定程序流程的程序计数器

    实际上一个命令和数据通常被储存在多个地址上,为了方便说明把指令和数据分配到一个地址中。
    假设地址0100为程序开始的位置。Windows等操作系统把程序从硬盘复制到内存后,会将程序计数器设定为0100,然后程序便开始运行。CPU每执行一条指令,程序计数器自动+1。然后CPU的控制器会参照程序计数器的数值,从内存中读取命令执行

条件分支和循环机制

程序的流程分为:

  • 顺序执行:执行按照地址内容的顺序执行指令。执行一条指令计数器+1。
  • 条件分支:根据条件执行任意地址的指令。计数器跳转到指定地址。
  • 循环:重复执行同一地址的指令。

    条件分支和循环中使用的跳转指令,会参照当前执行的运算结果来判断是否跳转。无论当前累加寄存器的运算结果是负数,零或正数,标志寄存器都会将其保存。(也负责存放溢出和奇偶校验的结果)。

  • 溢出( overflow )是指运算结果超出寄存器的长度范围。

  • 奇偶校验( parity check )是指检查运算结果的值是偶数还是奇数。
    是否执行跳转指令由CPU在参考标志寄存器的数值后进行判断。运算结果的正负和0三种状态由寄存器的三个字节位(0,1,2)表示。如下图:

    比较运算的结果储存在标志寄存器的三个位

  • 0位:运算结果为正则为1。

  • 1位:运算结果为0则为1。

  • 2位:运算结果为负则为1。

函数的调用机制

    单纯的跳转指令无法实现函数的调用,而是通过把程序计数器的值设定为函数的储存地址来实现。函数的调用需要在完成函数内部的处理后,处理流程再返回到函数的调用点(函数调用指令的下一地址)。因此,如果只是跳转到函数的入口地址,处理流程就不知道该返回到哪了。
    函数的调用使用call指令,在将函数的入口地址设定到程序计数器前,call指令会把调用函数后要执行的指令地址储存在名为的主存内。函数处理完后,再通过函数的出口来执行return命令(把保存在栈中的地址设定到程序计数器中)。

栈(stack):在程序领域中,栈表示不断储存各种数据的内存区域。函数调用能够返回调用前的地址就是因为栈。

通过地址和索引实现数组

    我们用十六进制数将计算机内存上00000000~FFFFFFF的地址划分出来。

实际查看的内存地址 = 基址寄存器的值 + 变址寄存器的值

    例如:要访问10000000~1000FFFF地址时,把10000000存入基址寄存器(基址寄存器的值被固定),然后变址寄存器中的值可在00000000~0000FFFF内变化,变址寄存器中的值,就相当于高级语言程序中数组的索引功能
    (用一个数组名来表示全体数据,通过索引来区分数组的各个数据。如,一个10元素的数组a,数据表示为a[0] ~ a[9],其中的数字0~9就是索引)

CPU处理简述

    下表对CPU能执行的机器语言指令进行分类。

类型 功能
数据转送指令 寄存器和内存,内存和内存,寄存器和外围设备之间的数据读写操作
运算指令 用累加寄存器的执行算术运算,逻辑运算,比较运算和移位运算
跳转指令 实现条件分支,循环,强制跳转等
call/return指令 函数的调用 / 返回调用前的结果

有关计算机二进制对数据进行表示及处理可参考:
明明是悟空 - 二进制的计算(计算机为什么采用补码储存数据)
张晓军 - 计算机中数的表示及运算

持续更新... ...

作者:SouthBegonia
链接:http://www.jianshu.com/p/q81RER/
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

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

推荐阅读更多精彩内容