C语言中unsigned和int的计算
(2011-10-11 09:42:57)
标签:
杂谈 |
分类: 技术向 |
有符号数和无符号数在一起运算,不要以为遵循的仍然是短的向长的靠齐。以前我们知道,如果一个short和一个int在一起运算,
首先编译器会将short自动转换为一个int类型中间变量,然后进行运算。但是有符号数和无符号数在一起运算的话,并不是这样。
借此机会,串下整形数据转换的相关知识。
反之一样。
编译器里面有标准的转换,这个是在整形运算的时候出现。标准转换的规则是:短的的向长的转;有符号的向无符号的转。如果被转换的数据比转换后的数据要长的话,转换可能会丢失bit数据。通常,编译器会给出警告。
无符号数据和有符号整数进行运算,是有符号整数向无符号整数靠齐。这里,我们可以总结一条规则:整形数运算,总是遵循一个原则:小的往大的扩展。
从小到达:short -> unsigned short -> int -> unsigned int
之所以这里有符号数类型长度比无符号数类型长度小,区别在于最高位使用与否。下面看看几个例子:
eg1:
eg2:
潜在:unsigned short--> int
潜在: long--> unsigned int
其它的如此类推