uchar类型加减运算

1、uchar 类型只能保存0-255的数字。超过了会溢出,溢出后会从0开始继续累加。所以小心使用

uchar u;

u +=u;

溢出了也不会提醒你

2、

计算机CPU只有加法逻辑运算器,对于减法运算,是使用两个数的补码进行加法运算。

50-100=?
50的二进制是:   00000000|00000000|00000000|00110010
50的补码是:     00000000|00000000|00000000|00110010(整数的补码不变)
100的二进制是:  00000000|00000000|00000000|0110010
-100的补码是:   先减1:100的二进制数 - 1 
                      =  00000000|00000000|00000000|01100011
                按位取反:00000000|00000000|00000000|01100011
                       = 11111111|11111111|11111111|10011100
(50的补码) + (-100的补码)是:00000000|00000000|00000000|00110010 +                                                                                          
                            11111111|11111111|11111111|10011100  
                          = 11111111|11111111|11111111|11001110

如果是无符号数,二进制转十进制: 
               11111111|11111111|11111111|11001110 = 4294967246
如果是有符号数,二进制转十进制: 
               11111111|11111111|11111111|11001110首位是1表示负数,
               先减1:11111111|11111111|11111111|11001101
               按位取反:00000000|00000000|00000000|00110010
               有符号数结果:  - (1*2^5 + 1*2^4 + 1*2^1)=-50
补码:

正数的补码,是其本身。

负数的补码,就用它的正数,减一取反,即可得到补码。

如,已知:+9 补码是:0000 1001。

下面求-9 补码:

先减一:0000 1001 - 1 = 0000 1000;

再取反:1111 0111。

所以有:-9 补码 = 1111 0111。

 

3、

50-100=-50, -50的二进制是补码表示为50取反+1,

50:   00000000|00000000|00000000|00110010 
取反:  11111111|11111111|11111111|11001101 
加1:   11111111|11111111|11111111|11001110 就是无符号数的 4294967246

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简易计算器的设计思路和实现方法: 1. 硬件设计: 1)使用数码管显示器来显示计算结果; 2)使用按键来输入数字和运算符; 3)使用51单片机来控制数码管和读取按键输入; 4)将数码管和按键分别连接到51单片机的IO口; 5)根据硬件连接情况编写IO口控制程序。 2. 软件设计: 1)读取按键输入,根据输入的数字和运算符进行计算; 2)在数码管上显示计算结果。 基于Keil C,以下是一个简易计算器的示例代码: ```c #include <reg52.h> #include <intrins.h> #define uint unsigned int #define uchar unsigned char // 按键输入的IO口 sbit KEY_ADD = P2^0; sbit KEY_SUB = P2^1; sbit KEY_MUL = P2^2; sbit KEY_DIV = P2^3; sbit KEY_EQ = P2^4; sbit KEY_CLR = P2^5; sbit KEY_0 = P2^6; sbit KEY_1 = P2^7; // 数码管IO口 sbit DIG_1 = P1^0; sbit DIG_2 = P1^1; sbit DIG_3 = P1^2; sbit DIG_4 = P1^3; sbit SEG_A = P1^4; sbit SEG_B = P1^5; sbit SEG_C = P1^6; sbit SEG_D = P1^7; uchar code DIG_TABLE[] = { // 数码管显示表 0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f }; // 数码管显示函数 void display(uint num) { uchar i; uchar dig[4]; for (i = 0; i < 4; i++) { dig[i] = num % 10; num /= 10; } for (i = 0; i < 100; i++) { // 防止闪烁 DIG_1 = 0; SEG_A = (dig[3] == 0 && i < 50); DIG_2 = 0; SEG_B = (dig[2] == 0 && i < 50); DIG_3 = 0; SEG_C = (dig[1] == 0 && i < 50); DIG_4 = 0; SEG_D = (dig[0] == 0 && i < 50); _nop_(); _nop_(); _nop_(); DIG_1 = 1; SEG_A = DIG_TABLE[dig[3]]; DIG_2 = 1; SEG_B = DIG_TABLE[dig[2]]; DIG_3 = 1; SEG_C = DIG_TABLE[dig[1]]; DIG_4 = 1; SEG_D = DIG_TABLE[dig[0]]; _nop_(); _nop_(); _nop_(); } } // 读取按键输入函数 uchar read_key() { if (!KEY_0) return 0; if (!KEY_1) return 1; if (!KEY_ADD) return '+'; if (!KEY_SUB) return '-'; if (!KEY_MUL) return '*'; if (!KEY_DIV) return '/'; if (!KEY_EQ) return '='; if (!KEY_CLR) return 'C'; return 0; } void main() { uint num1, num2, result; uchar op, key; while (1) { num1 = num2 = result = op = 0; while (1) { key = read_key(); if (key >= '0' && key <= '9') { // 数字 num2 = num2 * 10 + key - '0'; display(num2); } else if (key == '+' || key == '-' || key == '*' || key == '/') { // 运算符 if (op != 0) { // 已有运算符,先计算上一次结果 switch (op) { case '+': result = num1 + num2; break; case '-': result = num1 - num2; break; case '*': result = num1 * num2; break; case '/': result = num1 / num2; break; } num1 = result; num2 = 0; display(result); } op = key; } else if (key == '=') { // 等于号,计算结果 switch (op) { case '+': result = num1 + num2; break; case '-': result = num1 - num2; break; case '*': result = num1 * num2; break; case '/': result = num1 / num2; break; } num1 = result; num2 = 0; op = 0; display(result); } else if (key == 'C') { // 清空,重置状态 num1 = num2 = result = op = 0; display(0); while (read_key() == 'C') {} // 等待按键释放 } } } } ``` 这个代码实现了基本的加减乘除运算和清空功能。需要根据具体的硬件连接和需求进行修改和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值