因此,为了完成我的作业,我必须用C模拟基本的机器语言。这台机器有16个寄存器(reg[])、一个程序计数器(pc)和内存(mem[]),所有这些都是无符号字符。指令从文件中读入,格式如下:
B404(1RXY=用存储器地址XY的值加载寄存器R)。所有数字都是十六进制的。C000是停止命令。
现在我的问题是,当我打印出指令时(当存储在a,b,c,d和cd中时),b和d有前导零。如何摆脱它们,以便按上述方式打印说明?(第48行)。
另外,我的一些if语句似乎没有被调用,就好像我在其中放了printf()一样,而且它们在文件中,它从未被打印出来。(第48至78行)。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main () {
FILE *file;
file = fopen("a3.txt","r");
unsigned int temp = 0;
unsigned char pc, mem[256], reg[16],a,b,c,d,cd;
unsigned int count;
count = 0;
pc = 0;
for (int i=0; i < 16;++i) {
reg[i] = 0;
}
if (file == NULL) {
printf("\n Error opening the file");
exit(0);
}
for (int i=0; !feof(file); i += 2) {
fscanf(file, "%X", &temp);
mem[i] = ((temp & 0xFF00) >> 8);
mem[i + 1] = (temp & 0xFF);
if (feof(file)) {
break; // exit from while
}
++count;
}
int fclose(FILE *file);
/*while (mem[pc] != 0xC0) {*/
for (unsigned int i=0; i < count-1;++i) {
if (mem[i] == 0xC0) {
break; // exit from for
exit(1);
}
cd = mem[pc + 1];
a = (mem[pc] & 0xF0);
b = (mem[pc] & 0xF);
c = (mem[pc + 1] & 0xF0);
d = (mem[pc + 1] & 0xF);
printf("%02X ",pc);
printf("%X%X%X%X - [",a,b,c,d);
printf("%02X %02X %02X %02X ",reg[0],reg[1],reg[2],reg[3]);
printf("%02X %02X %02X %02X ",reg[4],reg[5],reg[6],reg[7]);
printf("%02X %02X %02X %02X ",reg[8],reg[9],reg[10],reg[11]);
printf("%02X %02X %02X %02X]\n",reg[12],reg[13],reg[14],reg[15]);
if (a == 0x1) {
reg[b] = reg[cd];
}
if (a == 0x2) {
reg[b] = cd;
//printf("2 reporting in");
}
if (a == 0x3) {
reg[cd] = reg[b];
}
if (a == 0x4) {
reg[d] = reg[c];
}
if (a == 0x05) {
reg[d] = (reg[b] + reg[c]);
//printf("5 reporting in");
}
if (a == 0x7) {
reg[d] = (reg[b] | reg[c]);
}
if (a == 0x8) {
reg[d] = (reg[b] & reg[c]);
}
if (a == 0x9) {
reg[d] = (reg[b] ^ reg[c]);
}
if (a == 0xA0) {
reg[b] = (reg[b] >> reg[d]) | (reg[b] << (32 - reg[d]));
}
pc += 2;
if (a == 0xB0) {
//printf("B reporting in");
if (reg[b] == reg[0]) {
pc = cd;
}
}
}
return 0;
}
谢谢!
最佳答案
要获取无符号字符的高位,请使用以下函数:
unsigned char hi(unsigned char bits) {
return (bits >> 4) & 0x0F;
}
在执行指令分派时,最好使用
switch
语句,而不是if ... else if ... else
级联。然后您可以使用一个简单的default: fprintf(stderr, "unknown instruction: %u\n", a); exit(1);
进行错误检测。另外,
0xA0
不是值10,而是160,所以您应该编写10
或0x0A
。更新:
提取
a
、b
、c
和d
的代码应如下所示:a = (mem[pc + 0] >> 4) & 0x0F;
b = (mem[pc + 0] >> 0) & 0x0F;
c = (mem[pc + 1] >> 4) & 0x0F;
d = (mem[pc + 1] >> 0) & 0x0F;
这很容易阅读,也很容易检查正确性。我们可以清楚地看到统一处理,并且每个值都被限制在
[0x00;0x0F]
的范围内。关于c - 在C中模拟基 native 器语言。,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/7440997/