博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
程序是如何执行的(一)a=a+1
阅读量:5717 次
发布时间:2019-06-18

本文共 2223 字,大约阅读时间需要 7 分钟。

本文链接:

一、概述

1、计算机中有两个主要的核心部件:CPU和内存,其中CPU负责运算而内存负责存储程序和相关的变量,每一条程序语句和变量都在内存中有对应的内存地址。

2、寄存器是CPU的存储单元,每一个CPU都会有通用寄存器来给程序使用,编号R1~R32,代表有32个通用寄存器。

3、CPU中的核心部件

(1)程序计数器PC(Program Counter)

  程序计数器是一个特殊的寄存器部件,程序执行时,PC始终指向内存中的某条指令语句(即该条语句的内存地址),然后CPU就是读取(PC)所指向的那条指令执行。

  在顺序执行程序语句时,PC通过顺序加1(32位CPU一个指令占4字节,64位8字节)自动指向下一条要执行的程序语句。但是对于一些控制结构语句如if else for while这时PC的值就不是顺序加1指向下一条语句了。

(2)指令寄存器IR(Instruction Register)

  指令寄存器也是一个特殊的寄存器,用来存放从内存中读取的指令。CPU从内存中读取指令到IR之后,由特定部件来解读这条指令,并执行相关的操作。

(3)算术逻辑单元ALU(arithmetic logic unit)

  ALU是处理器中进行真实运算的部件,执行指令时,CPU把寄存器中的值输入到ALU中,ALU做完运算后把结果存回寄存器

二、a=a+1

1、

对于a=a+1这条程序语句需要分解为三步,1、把变量a读取到某一个寄存器R存储,2、CPU对寄存器R的值进行计算,3、计算完成后将值存回内存

分解“a=a+1”的执行步骤:

第一步,CPU从地址300处读取第一条语句,CPU执行“读取a到R"语句,就会从地址1000出将a的值读到寄存器R中。

第二步,CPU从地址301处读取第二条语句,执行"R+1"语句,CPU会对R执行加1的操作

第三步,CPU从地址302出读取第三条语句,执行"将R存回a"语句,把寄存器R中变量a的值存回到内存中地址1000处。

2、汇编指令的概念

汇编指令由操作码和操作数组成,操作码是指令执行的基本动作,在load R1,(address)中,load是操作码,其后的寄存器R1和(address)都是操作数

  (1)"读取a到R"操作-load指令:

  load执行用来表示"CPU将内存中的a读取到寄存器R中"的操作。load指令需要有两个操作数。格式:load R1,(address),address是内存地址,(address)表示这个地址内存的值。例load R1,(1000)表示将地址1000处的变量值读取到寄存器R1中。

  (2)"R赋值"操作-mov指令:

  格式:mov R1,constant        mov用来将一个数赋给寄存器,mov指令有两个操作数前一个是寄存器,后一个是十六进制常数。例mov R1,0Ah表示将0Ah(十进制10)赋给寄存器R1。mov R2,R1表示将寄存器R1的值赋值给R2。

  (3)"R加1"操作-add指令

  格式:add R2,R1,constant    表示将R2=R1+constant。例add R2,R1,01h表示将寄存器R1中的值加1后将结果存到R2。例add R1,R1,R2表示将R1与R2的值相加将和存回R1。

  (4)减法指令-sub

  格式:sub R2,R1,constant  表示R2=R1-constant。例sub R3,R1,R2表示R3=R1-R2

  (5)左移位指令shiftl

  格式shiftl R2,R1,constant  表示R1寄存器的值左移constant位然后将值存入R2,左移一位就相当于乘以2,左移两位就相当与乘以4。例:

shiftl R2,R1,05h表示R2 = R1 * 2的5次方

  (6)右移位指令shiftr

  (7)"将R存回a"操作-store指令

  格式:store (address),R1     程序语句中的存回表示将寄存器R中的值存回到内存中。address是内存地址,(address)是要存回的值,R1是寄存器。例:store (500),R1表示将寄存器R1中的值存入到内存地址500处

 

3、a=a+1的完整执行过程

首先用汇编指令表示一下这个过程(a = 10;a = a + 1):

mov R1,0Ahstore (1000),R1load R1,(1000)add R1,R1,01hstore (1000),R1

具体执行过程:

(1)CPU从地址301处开始执行,PC的值为301,CPU从地址301处读取mov指令到IR,解读并执行mov指令,给寄存器R1中的变量赋初值10,然后PC加1,指向下一条汇编指令

(2)PC值为302,CPU从地址302处读取store指令到IR,解读并执行store指令,将寄存器R1中的变量a的值存到内存地址1000处,然后PC加1指向下一条汇编指令

(3)PC的值为304,CPU从地址304处读取add指令到IR,解读并执行add指令,将寄存器R1中变量a的值加1,并将结果再存回寄存器R1,然后PC加1,指向下一条汇编指令。

 

本文参考书籍:《计算机科学导论:以Python为舟》

 

转载于:https://www.cnblogs.com/orlion/p/5058441.html

你可能感兴趣的文章
mysql 5.7.19主从复制_MySQL5.7.19 - 主从复制 - 日志点
查看>>
网络安全态势感知 提取 理解和预测 杜嘉微_网络安全态势感知综述(二)
查看>>
bash给脚本加进度条_shell脚本实现进度条以及应用场景
查看>>
servlet存入mysql乱码_解决servlet中的乱码问题
查看>>
mysql 3523 redo_MySQL 持久化保障机制-redo 日志
查看>>
proxool mysql_proxool 连接mysql数据库的配置(web.xml) 以及简单的测试连接
查看>>
rocketmq存储消息mysql_RocketMQ 分布式事务消息
查看>>
用户态到内核态的转换的具体流程_Linux内核分析-系统调用用户态到内核态流程(四)...
查看>>
编程实现让单片机在lpm0模式下_奥运倒计时器,请看单片机如何编程实现
查看>>
docker进入容器安装东西的目录_Jenkins 在 docker 容器中安装
查看>>
python多包运行_Python-包的运行
查看>>
python打印机html css_python学习HTML之CSS(2)
查看>>
python的内存回收机制原理_python的内存管理和垃圾回收机制详解
查看>>
ubuntu 转mysql_【转】ubuntu 下安装mysql
查看>>
druid mysql 版本_Druid连接池错误(数据库版本问题)
查看>>
java读数据_java读写数据
查看>>
java php 性能比较_JAVA和PHP的优劣对比
查看>>
最大的矩形 java_最大矩形 - HelloJava菜鸟社区
查看>>
java读取excel数字类型_POI读取Excel 各种特殊数字和类型的转换。
查看>>
java remove 返回值_Java Scanner remove()方法
查看>>