计算机系统要素--第六章,02-HACK汇编编译器实现
從零開(kāi)始構(gòu)建現(xiàn)代計(jì)算機(jī)--第六章,02-HACK匯編編譯器實(shí)現(xiàn)
- 要點(diǎn)
- A-指令
- C-指令
- 符號(hào)表
- python實(shí)現(xiàn)
要點(diǎn)
關(guān)心三點(diǎn):
A指令,C指令,符號(hào)表
A-指令
A指令:將@num的num轉(zhuǎn)為16位的二進(jìn)制數(shù)即可
C-指令
C指令:分成四部分,固定的開(kāi)頭"111"(C指令標(biāo)志),comp域(執(zhí)行什么運(yùn)算),dest域(計(jì)算結(jié)果的輸出位置),jump域(是否跳轉(zhuǎn))
符號(hào)表
符號(hào)表保存的有編譯器預(yù)定義的符號(hào),以及匯編代碼中自定義的標(biāo)簽和變量的地址
預(yù)定義符號(hào):符號(hào)表初始化就添加
自定義標(biāo)簽和變量
標(biāo)簽的entry在第一趟添加到符號(hào)表中
變量的entry在第二趟添加到符號(hào)表中,變量定義就是在符號(hào)表中建立一個(gè)entry,這就是為什么變量的定義要先于它的使用
標(biāo)簽涉及控制流程,用來(lái)進(jìn)行地址跳轉(zhuǎn), 是A指令,
標(biāo)簽定義如(LOOP),用法是@LOOP
第一趟遇到(LOOP)要將標(biāo)簽加入符號(hào)表中,加的entry是下一條指令的位置,
第二趟忽略(LOOP),遇到@LOOP時(shí)取出entry,轉(zhuǎn)為二進(jìn)制數(shù)即是A指令的匯編代碼
python實(shí)現(xiàn)
可以參考github上一個(gè)哥們的python代碼
這份代碼不是可重定位的,因?yàn)樽兞糠峙涞钠鹗嫉刂饭潭榱?6
總結(jié)
以上是生活随笔為你收集整理的计算机系统要素--第六章,02-HACK汇编编译器实现的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 【man】getsockopt 和 se
- 下一篇: java网上书店系统_基于JAVA/JS