C 语言的 int 类型变量范围是多少?

Python013

C 语言的 int 类型变量范围是多少?,第1张

C语言的int类型变量范围是-32,768 to 32,767 或者 -2,147,483,648 到 2,147,483,647。

C语言int的取值范围在32/64位系统中都是32位,范围为-2147483648~+2147483647,无符号情况下表示为0~4294967295。

C/C++编程语言中,int表示整型变量,是一种数据类型,用于定义一个整型变量,在不同编译环境有不同的大小,不同编译运行环境大小不同。

C的数据类型包括:整型、字符型、实型或浮点型(单精度和双精度)、枚举类型、数组类型、结构体类型、共用体类型、指针类型和空类型。

整型变量是一种计算机语言。在C语言中,整型变量的值可以是十进制,八进制,十六进制,但在内存中存储着是二进制数。变量顾名思义是数值可以变的量,整型变量表示的是整数类型的数据。

C语言诞生得非常早,当时人们普遍还习惯用汇编语言编写软件,并且没有什么统一,通用的操作系统,基本上软件都是从0开始写的。C语言的方针便是比汇编方便易用,一起不要损失汇编的表达能力。所以C语言可以看成是“高级的汇编”语言。

C语言的源代码基本上可以非常容易地对应到汇编代码,并且可以不需要什么运行时环境的支撑。C的特点,简单容易编译,灵活贴近底层。所以一向到现在,一些需要直接和硬件打交道的软件都还是用C语言写的,比如(但不限于)Linux Kernel和一些嵌入式领域。

64位机器中,int占32位,取值范围为-2147483648~2147483647(-2^32~2^32-1)。

int类型的情况:

shortint类型可能占用比int类型更少的存储空间,C保证short类型至少16位长,用于只需小数值的场合以节省空间。

longint类型(或简写为long类型)可能占用比int类型更多的存储空间,C保证short类型至少32位长,用于使用大树枝的场合。

longlongint类型(或简写为longlong类型)可能占用比long类型更多的存储空间,C保证short类型至少64位长,用于使用更大数值的场合。

扩展资料

C语言的整型溢出问题int

int为4字节32位,其中首位用0表示正数,用1表示为负数。因此对于

最大正数可以表示为:0x7fffffff(7的二进制为0111,f二进制为1111)

最大负数(-1)可以表示为:0xffffffff

最小负数可以表示为:0x80000000(8的二进制为1000)

负数为正数的源码取反码再取补码,过程如下:

1、-1的原码:10000000000000000000000000000001

2、得反码:11111111111111111111111111111110

3、得补码:11111111111111111111111111111111

结论,取值范围是-2^31~2^31-1(十六进制为0x80000000~0x7fffffff)。因为0既不是正数也不是负数,+0是0,-0是最小的负数(-最大正数-1),所以负数的取值范围比正数多一个数。

int为四个字节,一共32位,其中最高位为符号位,0表示正数,1表示负数,剩下的31位表示数。所以一共可表示2*2^31即2^32个数字(包括一个0)。

在计算机中保存有符号数,保存的是数的二进制的补码,正数的源码、反码、补码相同,负数的反码为源码除符号位之外其余位取反,补码为反码+1(符号位不参与这个运算)。

在计算机中,正数为常量,且源码和补码相同,所以存储正数直接存就行。而负数因为有一个负号-,所以负数是一个计算表达式,都是由负数的绝对值计算出该负数的补码后存储在计算机中的。

求负数的补码值的时候,如-5,首先确定其符号位是1,后面写出其绝对值的二进制形式,28个0后面跟101,反码为29个1后面跟010,再加1就是补码29个1后面跟011,那么-5在计算机中就是存为29个1后面跟011。

所以可知0是32个0,最大正整数为0后面31个1,即2^31-1(2^31个数里包含了0,所以正数的个数要减去一个)。按理说正负数应该是对称的,最小的负数应该是-最大正整数,即-(2^31-1),为什么实际上最小的负数为  -最大正整数-1?为什么-0是最小的负数?

注意,虽然  -最大正整数-1  就是 -(2^31-1)-1 = -2^31,但是写的时候不能写 int i = -2^31因为说了负数其实是一个计算表达式,实际上是先对正数取反然后加1,符号位置为1,但是正数最大值是2^31-1,所以写-2^31是溢出的,这涉及到另外一个知识点。

先解释为什么-0是最小的负数(负的最大正整数-1)。

负的最大正整数的源码:32个1。反码:1后面跟31个0。补码:左右各1个1,中间30个0。所以,负的最大正整数(-(2^31-1))在计算机中存储为:1三十个零1。负的最大正整数-1就是负的最大正整数加-1。-1的补码为:32个1(十六进制为0xffffffff),那么两个补码相加:1三十个零1 + 32个1 = 1三十一个零。所以  负的最大正整数减一  的补码为:1三十一个零(十六进制为0x80000000),那么可以推断出其反码是32个1,则源码是1三十一个零,即-0,所以-0就是  负的最大正整数减一  ,-0的源码和补码相同。

那么为什么最小的负数是  负的最大正整数-1,为什么不能是负的最大正整数-2,或者减3......,因为通过计算,负的最大正整数的补码+负二的补码=0后面跟三十一个1,变成了最大的正整数。显然是不对的,同一个补码只能表达一种含义,减3同理,所以就规定最小的负数为负的最大正整数-1。