有符号数 、无符号数 浅析

本文详细解析了C语言中32位int类型的有符号数与无符号数的区别,包括它们的数据范围、表示方式及在实际编程中的应用。通过具体代码示例展示了如何在表达式中使用这两种类型,并解释了它们之间运算的优先级。同时,文章还探讨了无符号数与有符号数混合运算时的自动转换机制及其对结果的影响。

1. 32位int类型

  • 有符号数  

     signed int a ;  //默认情况下声明的整型变量都是有符号的的

     最高位是符号位, 0为正,1为负, 低31位表示数值大小,数据范围为:  - 2^31  到  2^31 -1  ,因为有个0 ,所以要减1

  • 无符号数

     unsigned int  a;

     32位中均表示数值大小,没有正负之分  , 所以数据范围为: 0 到 2^32 -1


#include<stdio.h>
int main()
{
    unsigned int a=6;
    signed int b=-20;  
    
    printf("%d\n",a+b);

    if( (a+b)>6 )
    {
        printf("---------------1\n");
    }
    else
    {
        printf("---------------2\n");
    }

    return 0;


结果是: -14    ------------1


    当表达式中存在有符号类型无符号类型时所有的操作数都自动转换为无符号类型。因此,从这个意义上讲,
无符号数的运算优先级要高于有符号数,这一点对于应当频繁用到无符号数据类型的嵌入式系统来说是丰常重要的。

    -14 > 6  编译器会自动转化为无符号数来进行处理,因此a+b = -14 +2^32 = 4294967282 这样比较下去当然6了

 
再进行一个实验,分别定义一个signed int型数据和unsigned int型数据,然后进行大小比较:
    unsigned int a=20;
    signed int b=-130;

a>b?还是b>a?实验证明b>a,也就是说-130>20,为什么会出现这样的结果呢?
这是因为在C语言操作中,如果遇到无符号数与有符号数之间的操作,编译器会自动转化为无符号数来进行处理,因此a=20,b=-130+2^32 = 4294967166,这样比较下去当然b>a了。










评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值