计算机组成原理无符号数的加减运算假定一个八位字长的计算机中运行如下c程序段unsigned int x=134;unsighed int y=246;int m=x;int n=y;unsigned int z1=x-y;unsigned int z2=x+y;int k1=m-n;int k2=m+n;若编译器编译时将8
来源:学生作业帮助网 编辑:作业帮 时间:2024/07/30 21:42:42
![计算机组成原理无符号数的加减运算假定一个八位字长的计算机中运行如下c程序段unsigned int x=134;unsighed int y=246;int m=x;int n=y;unsigned int z1=x-y;unsigned int z2=x+y;int k1=m-n;int k2=m+n;若编译器编译时将8](/uploads/image/z/2766272-32-2.jpg?t=%E8%AE%A1%E7%AE%97%E6%9C%BA%E7%BB%84%E6%88%90%E5%8E%9F%E7%90%86%E6%97%A0%E7%AC%A6%E5%8F%B7%E6%95%B0%E7%9A%84%E5%8A%A0%E5%87%8F%E8%BF%90%E7%AE%97%E5%81%87%E5%AE%9A%E4%B8%80%E4%B8%AA%E5%85%AB%E4%BD%8D%E5%AD%97%E9%95%BF%E7%9A%84%E8%AE%A1%E7%AE%97%E6%9C%BA%E4%B8%AD%E8%BF%90%E8%A1%8C%E5%A6%82%E4%B8%8Bc%E7%A8%8B%E5%BA%8F%E6%AE%B5unsigned+int+x%3D134%3Bunsighed+int+y%3D246%3Bint+m%3Dx%3Bint+n%3Dy%3Bunsigned+int+z1%3Dx-y%3Bunsigned+int+z2%3Dx%2By%3Bint+k1%3Dm-n%3Bint+k2%3Dm%2Bn%3B%E8%8B%A5%E7%BC%96%E8%AF%91%E5%99%A8%E7%BC%96%E8%AF%91%E6%97%B6%E5%B0%868)
计算机组成原理无符号数的加减运算假定一个八位字长的计算机中运行如下c程序段unsigned int x=134;unsighed int y=246;int m=x;int n=y;unsigned int z1=x-y;unsigned int z2=x+y;int k1=m-n;int k2=m+n;若编译器编译时将8
计算机组成原理无符号数的加减运算
假定一个八位字长的计算机中运行如下c程序段
unsigned int x=134;
unsighed int y=246;
int m=x;
int n=y;
unsigned int z1=x-y;
unsigned int z2=x+y;
int k1=m-n;
int k2=m+n;
若编译器编译时将8个8位寄存器R1~R8分别分配给变量x、y、m、n、z1、z1、k1、k2;
问:执行上述程序段后,寄存器R1、R5、R6
的内容分别是什么?
我计算的R5
x=10000110
y=11110110
计算z1=x-y
是不是因为他们都寄存在八位的寄存器里
所以x-y:
1000 0110
- 1111 0110
----------------
1001 0000
z1=90H
这样计算对么?
计算机组成原理无符号数的加减运算假定一个八位字长的计算机中运行如下c程序段unsigned int x=134;unsighed int y=246;int m=x;int n=y;unsigned int z1=x-y;unsigned int z2=x+y;int k1=m-n;int k2=m+n;若编译器编译时将8
不对.
计算机的处理过程是:让减数经过一个反向器并加1,也就是取反,然后再送入ALU相加
所以是这样的
1000 0110
+0000 1010