C语言中,什么叫无符号整型数?

Python09

C语言中,什么叫无符号整型数?,第1张

C语言中,无符号整型数是不带正负表示符号的整型数。C语言在计算机里编译时数都是用二进制表示的,如果最左边这一位不用来表示正负,而是和后面的连在一起表示整数,那么就不能区分这个数是正还是负,就只能是正数,这就是无符号整型数。

无符号整型数常用于表示地址、索引等正整数,它们可以是8位、16位、32位、64位甚至更多。在一些不可能取值为负数的时候,可以使用无符号整型数,在一些底层的嵌入式编程的数据一般都是无符号的。

扩展资料:

整型有无符号(unsigned)和有符号(signed)两种类型,在默认情况下声明的整型变量都是有符号的类型(char有点特别),如果需声明无符号类型的话就需要在类型前加上unsigned。

无符号整型和有符号整型的区别就是无符号类型可以存放的正数范围比有符号整型中的范围大一倍,因为有符号类型将最高位储存符号,而无符号类型全都储存数字。比如16位系统中一个int能存储的数据的范围为-32768~32767,而unsigned能存储的数据范围则是0~65535。

有符号和无符号的区别就在于最高位

有符号的最高位是符号位,1表示负数,0表示正数

无符号所有数位都是表示数值的

当输入-1的时候,相当于赋值c=-1,根据补码规则,-1的十六进制在int类型下是0xffffffff,按照%d输出-1,按照%u输出无符号就是2的32次幂-1,也就是你输出的那个值

而如果定义unsigned char,实际上用%u或者用%d输入是有风险的,因为会实际赋值4个字节,本质上是越界的,正确做法是%hhd或者%hhu

不管怎么样,还是把赋值成了0xff,至于越界的三个字节赋值给谁就不知道了

用%u或者%d输出就都是255了,也就是2的8次幂-1这样的一个值

如果定义的不是unsigned char c,而是char c,那么你会得到另一个不同的结果了

需要准备的材料分别有:电脑、C语言编译器。

1、首先,打开C语言编译器,新建一个初始.cpp文件,例如:test.cpp。

2、在test.cpp文件中,输入C语言代码:unsigned int a = 1024printf("%u", a)。

3、编译器运行test.cpp文件,此时成功定义了无符号整数并进行了输出。