我需要回答的问题是,为什么第 9 行比较失败,而第 8 行没有比较失败?我是 Hack 汇编语言的新手,仍在学习基础知识,但对 CPU 模拟器为什么会通过第 8 行而不是第 9 行感到困惑。
第二个问题:
我怎样才能解决这个问题以支持负值的乘法?
程序将 R0 和 R1 相乘并将结果存储在 R2 中。(R0、R1、R2 分别指 RAM[0]、RAM[1] 和 RAM[2]。)
多重组合:
0 @2
1 M=0
2 @0
3 D=M
4 @8
5 D;JNE
6 @19
7 0;JMP
8 @2
9 D=M
10 @1
11 D=D+M
12 @2
13 M=D
14 @0
15 D=M-1
16 M=D
17 @8
18 D;JGT
19 @19
20 0;JMP
多.cmp:
| RAM[0] | RAM[1] | RAM[2] |
| 0 | 0 | 0 |
| 1 | 0 | 0 |
| 0 | 2 | 0 |
| 3 | 1 | 3 |
| 2 | 4 | 8 |
| 6 | 7 | 42 |
| 6 | -7 | -42 |
| -6 | 7 | -42 |