杏悦2首頁

杏悦2網站xml地圖

當前位置: 杏悦2 >> 知識庫 >> 正文
計算機的硬件組成及工作過程
發布時間👧💂🏼‍♂️:2024-05-08       編輯:網絡中心       瀏覽次數⌚️😬:

1.計算機的硬件組成

1.1 主存儲器

主存儲器包括存儲體M、各種邏輯部件以及控制電路等👨🏼‍🦰。為了能實現按地址訪問的方式👨‍👩‍👦‍👦,還必須配置兩個寄存器存儲器地址寄存器(MAR)和存儲器數據寄存器(MDR)🤾🏽‍♀️。

  • 存儲器地址寄存器(MAR):存放欲訪問的存儲單元的地址🚵🏼🦸🏽‍♂️,其位數對應存儲單元的個數。

  • 存儲器數據寄存器(MDR)🤴🏻🐽:存放從存儲體某單元取出的代碼或者准備往某存儲單元存入的代碼,其位數與存儲字長相等。

1.2 運算器

運算器最少包括3個寄存器和一個算術邏輯單元🤸🏻‍♂️🥊。

  • 累加器(ACC):存放操作數或運算結果。

  • 乘商寄存器(MQ)👮🏿‍♂️:在乘、除法運算時,用于存放操作數或運算結果。

  • 通用的操作數寄存器(X):存放操作數🪺。

  • 算術邏輯單元(ALU):通過內部複雜電路實現算術運算、邏輯運算👛。

1.3 控制器

控制器是計算機的神經中樞💆‍♂️,由它指揮各部件自動、協調地工作。

具體而言,它首先要命令存儲器讀出一條指令🧔🏼‍♂️,稱為取指過程。接著,它要對這條指令進行分析,指出該指令要完成什麼樣的操作,並按尋址特征指明操作數的地址,稱為分析過程🔐。最後根據操作數所在的地址以及指令的操作碼完成某種操作,稱為執行過程

  • 控制單元(CU):分析指令🫡,給出控制信息。

  • 指令寄存器(IR):存放當前執行的指令。

  • 程序計數器(PC)🧑‍🎤:存放下一條指令的地址🧑🏿‍🎨,有自動加1的功能🟫,即可自動形成下一條指令的地址🧑🏻‍🦱。

1.4 I/O

I/O子系統包括各種I/O設備及其相應的接口。每一種I/O設備都由I/O接口與主機聯系,它接收CU發出的各種控制命令,並完成相應的操作☘️。

1.5 細化的計算機組成框圖

 2. 計算機的計算過程

接下來用我們熟悉的一段代碼來了解一下計算機的計算過程。

int a = 2, b = 3, c = 1, y = 0;
void main()
{
y = a * b + c;
}

編譯並裝入主存儲器可以得到🧑‍🦽‍➡️:

 (1)取出數值a=2

  1. 初:(PC)=0🎵,指向第一條指令的存儲地址

  2. (PC)->MAR,導致(MAR)=0

  3. M(MAR)->MDR,導致(MDR)=00001 0000000101

  4. (MDR)->IR💇🏼‍♂️🫁,導致(IR)=00001 0000000101

  5. OP(IR)->CU,指令操作碼送到CU,CU分析後得知🙈,這是取指指令

  6. Ad(IR)->MAR🤺🎟,指令的地址碼送到MAR,導致(MAR)=0000000101=5

  7. M(MAR)->MDR,導致(MDR)=0000000000000010=2

  8. (MDR)->ACC,導致(ACC)=0000000000000010=2

(2)進行a*b

  1. 上一條指令取指後PC自動+1,(PC)=1;執行後,(ACC)=2

  2. (PC)->(MAR)📳,導致(MAR)=1

  3. M(MAR)->MDR✴️🛠,導致(MDR)=00100 0000000110

  4. (MDR)->IR,導致(IR)=00001 0000000110

  5. OP(IR)->CU👩🏿‍⚕️,指令操作碼送到CU,CU分析後得知,這是乘法指令

  6. Ad(IR)->MAR,指令的地址碼送到MAR,導致(MAR)=0000000110=6

  7. M(MAR)->MDR,導致(MDR)=0000000000000011=3

  8. (ACC)->X,導致(X)=2

  9. (MQ)*(X)->ACC,由ALU實現乘法運算,導致(ACC)=6👩‍❤️‍💋‍👩,如果乘積太大,則需要MQ輔助存儲

(3)進行(a*b)+c

  1. 上一條指令取指後(PC)=2♟,執行後(ACC)=6

  2. (PC)->(MAR)🌖,導致(MAR)=2

  3. M(MAR)->MDR,導致(MDR)=00011 0000000111

  4. (MDR)->IR,導致(IR)=00011 0000000111

  5. OP(IR)->CU🩵,指令操作碼送到CU,CU分析後得知🦿,這是加法指令

  6. Ad(IR)->MAR,指令的地址碼送到MAR,導致(MAR)=0000000111=7

  7. M(MAR)->MDR,導致(MDR)=0000000000000001=1

  8. (ACC)+(X)->ACC,由ALU實現加法運算⛔,導致(ACC)=7

(4)存儲y=a*b+c

  1. 上一條指令取指後(PC)=3,執行後(ACC)=7

  2. PC)->(MAR),導致(MAR)=3

  3. M(MAR)->MDR,導致(MDR)=00010 0000001000

  4. (MDR)->IR💅🏼,導致(IR)=00010 0000001000

  5. OP(IR)->CU,指令操作碼送到CU,CU分析後得知🦗,這是存數指令🏘、

  6. Ad(IR)->MAR,指令的地址碼送到MAR👨‍👦,導致(MAR)=0000001000=8

  7. (ACC)->MDR,導致(MDR)=7

  8. (MDR)->地址為8的存儲單元,導致y=7

 注意:

  1. M:主存中的某存儲單元

  2. ACC🙋‍♂️、MQ、X、MAR、MDR......:相應的存儲器

  3. M(MAR)👐🏿:去存儲單元中的數據

  4. (ACC)......:取相應存儲器中的數據

  5. OP(IR):取操作碼

  6. Ad(IR)🚈:取地址碼


來源✊🏽:https://blog.csdn.net/weixin_49370884/article/details/127077480

作者:

關閉本頁

杏悦2-【杏悦2娱乐新体验】立刻开启您的冒险之旅!教育技術與網絡中心版權所有

©GDAFC Education Technology & Network Center, All Rights Reserved.

杏悅2