uint8是8位无符号整型,uint16是16位无符号整型。

Posted lovexiong-victor

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了uint8是8位无符号整型,uint16是16位无符号整型。相关的知识,希望对你有一定的参考价值。

uint8是8位无符号整型,uint16是16位无符号整型。

整型有无符号(unsigned)和有符号(signed)两种类型,在默认情况下声明的整型变量都是有符号的类型(char有点特别),如果需声明无符号类型的话就需要在类型前加上unsigned。在一些不可能取值为负数的时候,可以定义为unsigned,在一些底层的嵌入式编程的数据一般都是无符号。

 

向左转|向右转

技术图片

 

扩展资料:

负数时的有符号整型和无符号整型的转换

当执行一个运算时(如这里的a>b),如果它的一个运算数是有符号的而另一个数是无符号的,那么C语言会隐式地将有符号 参数强制类型为无符号数,并假设这两个数都是非负的,来执行这个运算。

整数在计算机中通常是以补码的形式存在的,而-1的补码(用4个字节储存)为1111,1111,1111,1111。对大多数C语言的实现,处理同样字长的有符号数和无符号数之间的相互转换的一般规则是:数值可能会改变,但是位模式不变。

也就是说,将unsigned int强制类型转换成int,或将int转换成unsigned int底层的位表示保持不变。也就是说,即使是-1转换成unsigned int之后,它在内存中的表示还是没有改变,即1111,1111,1111,1111。

同样的储存表示对于应用程序而言可能对应着不同的数据,例如1111,1111,1111,1111对于有符号数而言它表示-1,但对于无符号数而言,它表示UMax(因为没有符号位,就像正数的反码补码都是它本身一样,且最高位也不表示符号位),但是它们的底层存储都是一样的。

以上是关于uint8是8位无符号整型,uint16是16位无符号整型。的主要内容,如果未能解决你的问题,请参考以下文章

uint是几位无符号整数?

uint是几位的整型啊,uint16是几位的?

网络编程中重要的几个数据结构和函数

句柄Windows数据类型

uint8_t 数据类型

如何使用缩放有效地将 16 位无符号短转换为 8 位无符号字符?