程序执行的过程分析--【sky原创】

简介: 程序执行的过程:     比如我们要执行3 + 2   程序计数器(PC) = 指令地址 指令寄存器(IR) = 正在执行的命令 累加器(AC) = 临时存储体   那么实际上执行了三条指令 每条指令又分为两部分:取址、执行   取址就是从寄存器里取一条指令放在IR寄存器...
程序执行的过程:
 

 
比如我们要执行3 + 2
 
程序计数器(PC) = 指令地址
指令寄存器(IR) = 正在执行的命令
累加器(AC) = 临时存储体
 
那么实际上执行了三条指令
每条指令又分为两部分:取址、执行
 
取址就是从寄存器里取一条指令放在IR寄存器
 
左上角的图,PC寄存器里面放的值是300
那么我们就从内存地址为300的位上取一条指令 1940的内容放到IR上去
 
一条指令 由操作码+操作数组成
 
1940  中的 1代表操作码,940代表操作数
 
1是从一个内存中取数据放入AC寄存器里面,即我要做什么操作
把940内存地址里面的数据0003放入AC寄存器
 
先取址,PC=300  执行时PC=301
PC会加1
 
 欢迎交流

新浪博客:http://blog.sina.com.cn/u/2049150530
csdn博客:http://blog.csdn.net/u011749143
博客园:http://www.cnblogs.com/sky-heaven/

知乎:http://www.zhihu.com/people/zhang-bing-hua

 
【作者】 张昺华
【新浪微博】 张昺华--sky
【twitter】 @sky2030_
【facebook】 张昺华 zhangbinghua
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
目录
相关文章
|
监控 网络协议 Perl
[原创]结合案例深入解析orphan socket产生与消亡(一)
本文看点:结合服务器运行案例和TCP代码分析orphan socket产生与消亡以及对系统的影响。精彩的部分在(二)细节分析章节。 ##问题背景 tengine服务器发生过多次orphan socket数量很多的情况,例如有一次使用ss -s命令查看: ``` $ss -s T
8016 0
|
1月前
|
缓存 编译器 程序员
C/C++编译器链接优化技术:链接优化是在编译器和链接器之间进行的优化
C/C++编译器链接优化技术:链接优化是在编译器和链接器之间进行的优化
36 0
|
8月前
|
Java
谈谈多线程和进程,附上例题讲解 2
谈谈多线程和进程,附上例题讲解
31 0
|
8月前
|
Java
谈谈多线程和进程,附上例题讲解 1
谈谈多线程和进程,附上例题讲解
74 0
谈谈多线程和进程,附上例题讲解 1
|
缓存 JavaScript 前端开发
学习 async,defer 和动态脚本,本文就够了!
学习 async,defer 和动态脚本,本文就够了!
140 0
学习 async,defer 和动态脚本,本文就够了!
|
缓存 Linux 索引
内核源码kfifo分析(原创)
从2.6.10开始,Linux内核提供了一个通用的环形缓存(我喜欢称为环形队列);它的头文件是<linux/kfifo.h>,kfifo.c是实现代码。 在设备驱动中环形缓存出现相当多. 网络适配器, 特别地, 常常使用环形缓存来与处理器交换数据(报文)[LDD3]。 见下面的图“LDD3中描述的队列”。 我们来看下kfifo的数据结构: struct kfifo { unsigned char *buffer; /* the buffer holding the data */ unsigned int size; /* the size of the al
558 0