C语言进阶第2式:有符号与无符号

这篇博客探讨了计算机中正负数的表示和存储方式,主要关注有符号数的补码表示法。通过三个示例展示了如何通过最高位判断数的符号,以及在混合无符号数和有符号数计算时可能遇到的问题。强调了在处理无符号数时的注意事项,特别是将其视为有符号数可能导致的错误。
摘要由CSDN通过智能技术生成

1、在计算机中正负数是如何表示和存储的?

在计算机中数据类型最高位用于标识数据的符号:

最高位为1,表明这个数为负数;

最高位为0,表明这个数为正数

在计算机中用补码表示有符号数(为什么用补码,可以查看《微机原理与接口技术》),规则如下:

正数的补码为正数本身,负数的补码为负数的绝对值各位取反后加1。

对于固定长度的无符号数:

MAX_VALUE + 1 -> MIN_VALUE

MIN_VALUE  -> MAX_VALUE

C语言中变量默认为有符号的类型

unsigned关键字声明为无符号类型,C语言中只有整数类型能够声明unsigned变量。

(即:unsigned只能修饰整数类型的变量。)

例1:有符号数的符号位

#include <stdio.h>

int main()
{
    char c = -5;
    short s = 6;
    int i = -7;
    
    printf("%d\n", ( (c & 0x80) != 0 ));
    printf("%d\n", ( (s & 0x8000) != 0 ));
    printf("%d\n", ( (i & 0x80000000) != 0 ));
    
    return 0;
}

例2:当无符号数与有符号数混合计算时,会将有符号数转换为无符号数后再进行计算,结果为无符号数,可能会造成错误。

#include <stdio.h>

int main()
{
 
    unsigned int i = 5;
    int j = -10;
    
    if( (i + j) > 0 )
    {
        printf("i + j > 0\n");
    }
    else
    {
        printf("i + j <= 0\n");
    }
    
    return 0;
}

例3:错误使用unsigned,不能将unsigned数据类型当成有符号数进行计算和输出。

#include <stdio.h>

int main()
{
 
    unsigned int i = 0;
    
    for(i=9; i>=0; i--)
    {
        printf("i = %u\n", i);
    }
    
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值