C语言中用unsigned的作用,C语言中unsigned和int的计算

本文探讨了有符号数和无符号数在整型运算中的转换规则,包括短的向长的靠齐、有符号向无符号转换的原则,以及不同类型的整数在运算时的具体转换过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有符号数和无符号数在一起运算,不要以为遵循的仍然是短的向长的靠齐。以前我们知道,如果一个short和一个int在一起运算,

首先编译器会将short自动转换为一个int类型中间变量,然后进行运算。但是有符号数和无符号数在一起运算的话,并不是这样。

借此机会,串下整形数据转换的相关知识。

首先说说符号数和无符号数之间的转换。无符号数可以转换为有符号数,有符号数也可以转化为无符号整形,这之间的转换一般编译器也不会给出警告,因为这种转换不涉及到bit丢失的情况,内存内容不会发生任何改变。仅仅是对这块内存的解释不一样而已。

例如: int a = -3;

unsigned int b= a; // b=

65533

反之一样。

编译器里面有标准的转换,这个是在整形运算的时候出现。标准转换的规则是:短的的向长的转;有符号的向无符号的转。如果被转换的数据比转换后的数据要长的话,转换可能会丢失bit数据。通常,编译器会给出警告。

无符号数据和有符号整数进行运算,是有符号整数向无符号整数靠齐。这里,我们可以总结一条规则:整形数运算,总是遵循一个原则:小的往大的扩展。

从小到达:short -> unsigned short -> int

-> unsigned int

之所以这里有符号数类型长度比无符号数类型长度小,区别在于最高位使用与否。下面看看几个例子:

eg1:

int a=-6;

unsigned int b = 3;

typeid(a+b)-----------------------unsigned

int a+b结果:为一个很大的整数

潜在:int --> unsigned int

eg2:

unsigned short s1 = 3;

int i2= -5;

typeid(s1+i2)

----------------------int a+b结果:-2

潜在:unsigned short--> int

eg3:

unsigned int s1 = 3;

long i2= -5;

typeid(s1+i2) ---------------------unsigned

int a+b结果:很大的正整数

潜在: long--> unsigned int

其它的如此类推

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值