胡构造世界计算机系统结构_第1页
胡构造世界计算机系统结构_第2页
胡构造世界计算机系统结构_第3页
胡构造世界计算机系统结构_第4页
胡构造世界计算机系统结构_第5页
已阅读5页,还剩15页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、0,1构造世界番外篇CPU内部指令执行过程计算机系统结构从3个角度来提高计算机利用率CPU、内存、I/O指令执行过程(1)指令地址怎么知道?指令如何取出来?如何分辨指令是做什么的?指令周期和时钟频率怎样配合?指令和数据的区别以及如何分辨取出的是数据还是指令?指令流水线怎样实现?设计原则化整为零指令执行过程(2)计算机系统结构如何解决CPU、内存、I/O不匹配的问题?设计原则划分同类事物提高计算机利用率提高CPU利用率CPU只有一个,同一时间只能有一个程序在运行,如何决定该运行哪个程序?设计原则轮流来,但要有先后;提高内存利用率如何给程序分配物理内存?地址如何重定位?怎样将碎片内存都利用起来?设

2、计原则同一对待所有程序;采用分割和映射的方式有效利用闲散资源;提高硬盘利用率硬盘空间如何划分?文件在硬盘中如何被组织?设计原则化零为整正式篇预处理编译词法分析语法分析语义分析中间代码生成汇编代码生成词法分析Example: arrayindex = (index + 4) * (2 + 6)array标识符右方括号index标识符左方括号=赋值运算符(右括号index标识符+加号运算符语法分析Example: arrayindex = (index + 4) * (2 + 6)=arrayindex*+index4+62语义分析Example: arrayindex = (index + 4)

3、 * (2 + 6)=intintarrayarray of intindexint*int+intindexint4int+int6int2int中间代码生成三地址码:x = y op zExample: arrayindex = (index + 4) * (2 + 6)t1 = 2 + 6;t2 = index + 4;t3 = t2 * t1;arrayindex = t3;t2 = index + 4;t2 = t2 * 8;arrayindex = t2;汇编代码生成Example: arrayindex = (index + 4) * (2 + 6)mov index,%ecx;add $4,%ecx;mul $8,%ecx;mov index,%eax;mov %ecx,array(,eax,4);t2 = index + 4;t2 = t2 * 8;arrayindex = t2;链接int global_init_var = 84;int global_unit_var;void func1(int i)printf(%dn, i);int main()static int static_var = 85;static int static_var2;int a

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论