C语言int的取值范围

发布网友 发布时间:2022-03-25 18:03

我来回答

9个回答

懂视网 时间:2022-03-25 22:24

int的意思是基本整型,计算取值范围:

  

  1、当字节数为2时,取值范围为-32768到32767。

  

  2、当字节数为4时,取值范围为负的2的31次方,到2的31次方减1。

  

  nt类型在内存中占用了4个字节,也就是32位。int类型是有符号的,因此,32位并不会全部用来存储数据,使用最高位来存储符号,最高位是0,提示数据是正数,最高位是1,表示数据是负数,使用其他的31位来存储数据。C语言没有规定各种整数类型的表示范围,也就是说,没有规定各种整数的二进制编码长度,对于int和long,只规定了long类型的表示范围不小于int,但也允许它们的表示范围相同。具体C语言会对整型和长整型规定表示方式和表示范围。

  

  整数(int类型的常量)有几种书写形式,程序中的整数一般采用十进制写法。用十进制方式写出的一个整数就是普通数字字符组成的一个连续序列,其中不能有空格、换行或其他字符。C语言规定十进制表示的数字不能是0,除非要写的整数本身就是0。

热心网友 时间:2022-03-25 19:32

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

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

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

基本数据类型:

void:声明函数无返回值或无参数,声明无类型指针,显示丢弃运算结果。(C标准新增)

char:字符型类型数据,属于整型数据的一种。(K&R时期引入)

int:整型数据,表示范围通常为编译器指定的内存字节长。(K&R时期引入)

float:单精度浮点型数据,属于浮点数据的一种。(K&R时期引入)

double:双精度浮点型数据,属于浮点数据的一种。(K&R时期引入)

_Bool:布尔型(C99标准新增)

_Complex:复数的基本类型(C99标准新增)

_Imaginary:虚数,与复数基本类型相似,没有实部的纯虚数(C99标准新增)

_Generic:提供重载的接口入口(C11标准新增)

扩展资料:

19年,ANSI发布了第一个完整的C语言标准——ANSI X3.159—19,简称“C”,不过人们也习惯称其为“ANSI C”。

C在1990年被国际标准组织ISO(International Standard Organization)一字不改地采纳,ISO官方给予的名称为:ISO/IEC 99,所以ISO/IEC99: 1990也通常被简称为“C90”。

1999年,在做了一些必要的修正和完善后,ISO发布了新的C语言标准,命名为ISO/IEC 99:1999,简称“C99”。

在2011年12月8日,ISO又正式发布了新的标准,称为ISO/IEC99: 2011,简称为“C11”。

参考资料:

百度百科-C语言

百度百科-int函数

热心网友 时间:2022-03-25 20:50

16位的int取值范围分为无符号整型(unsigned int)和有符号整型(signed int)。

无符号整型是0000 0000 0000 0000 ~ 1111 1111 1111 1111,对应的十进制数为0到65535(即2^16-1)。

要理解有符号整型首先要了解两个规定:

符号位:对于有符号整型,存储单元中最高位代表符号位:0为正,1为负。

有符号整型的负数表示方法:补码(原码先取反再加1得到补码)。

-------------------------------------------------------------------------------

举例:表示16位的-1。

1的原码:0000 0000 0000 0001;

取反(01互换):1111 1111 1111 1110;

加1:1111 1111 1111 1111。

得到-1的补码为1111 1111 1111 1111。

所以16位二进制有符号整型的-1就表示为1111 1111 1111 1111。

-------------------------------------------------------------------------------

所以16位二进制数有符号整型的表示范围为:

正数,最高位为0,取值范围如下:

0000 0000 0000 0001 到 0111 1111 1111 1111

对应的十进制数为1到32767(2^15-1)。

0,全部位为0:

0000 0000 0000 0000。

负数,最高位为1,取值范围如下(以补码形式表示):

1111 1111 1111 1111 到 1000 0000 0000 0000 

对应的十进制数为-32768到-1,即-2^15到-1。

综上,16位二进制数有符号整型的取值范围是-32768到32767。

加深理解:题主问题中问-32768(-2^15)怎么来的,1000 0000 0000 0000在无符号整型中表示2^15怎么在有符号整型中就表示-2^15了呢?这里可以通过补码减1取反倒推出原码。

补码:1000 0000 0000 0000

减1:0111 1111 1111 1111

取反得到原码:1000 0000 0000 0000(2^15)

原码补码相同,只是个巧合。

热心网友 时间:2022-03-25 22:25

C语言中int的取值范围为:-21474838 ~ 21474837

解释如下:
int类型在C语言中占4个字节,即32个二进制位。

当表示正数时,最高位为符号位(符号位为0),最大的正数是 0111 1111 1111 1111 1111 1111 1111 1111 即2^31 -1 = 21474837
当表示负数时,最高位为符号位(符号位为1),最小的负数是 1000 0000 0000 0000 0000 0000 0000 0000 而在计算机中是以补码的形式存储的,C语言规定 1000 0000 0000 0000 0000 0000 0000 0000 的补码为-21474838
所以C语言中int的取值范围为:-21474838 ~ 21474837

热心网友 时间:2022-03-26 00:16

c语言int的取值范围在32/位系统中都是32位,范围为-21474838,+21474837,无符号情况下表示为0,4294967295。c/c++编程语言中,int表示整型变量,是一种数据类型,用于定义一个整型变量,在不同编译环境有不同的大小,不同编译运行环境大小不同。c的数据类型包括:整型、字符型、实型或浮点型(单精度和双精度)、枚举类型、数组类型、结构体类型、共用体类型、指针类型和空类型。基本数据类型:void:声明函数无返回值或无参数,声明无类型指针,显示丢弃运算结果。(c标准新增)。char:字符型类型数据,属于整型数据的一种。(k&r时期引入)。int:整型数据,表示范围通常为编译器指定的内存字节长。(k&r时期引入)。float:单精度浮点型数据,属于浮点数据的一种。(k&r时期引入)。double:双精度浮点型数据,属于浮点数据的一种。(k&r时期引入)。_bool:布尔型(c99标准新增)。_complex:复数的基本类型(c99标准新增)。_imaginary:虚数,与复数基本类型相似,没有实部的纯虚数(c99标准新增)。_generic:提供重载的接口入口(c11标准新增)。

热心网友 时间:2022-03-26 02:24

负数是用补码保存的,所以1111 1111 1111 1111 按十六位有符号整数转换为十进制数字就是-1,是最大的负整数。

-32768的转换过程是:

先将32768(-32768的绝对值)按位取反,结果就是0111 1111 1111 1111

之后再将取反后的结果加1,就得了-32768的二进制存储:1000 0000 0000 0000

请自行查找 补码 的相关知识仔细研读吧!

热心网友 时间:2022-03-26 04:49

二进制数在计算机内存储的是其补码
对于有符号数,正数的补码和本身一样,负数的补码是本身的数字位取反后加1
比如:
1=(0001)补=(0001)
-1=(1001)补=(1111)
计算机存储-1就是存储的1111
因此
当int表示范围为16位时,可以表示的最大负数为:
10000...0000(后面有15个0)
相当于-0
但这其实是-32768=110000...0000(第一位符号位,后面有15个0)的补码表示
可以理解为16位的int足可以表示-32768的补码

热心网友 时间:2022-03-26 07:30

在写程序的时候最好用C库定义好的宏或函数,
因为int的范围因机器而异。为了避免在程序中直接写死最大值。
C库会用条件编译根据你的机器选择正确的最大值。

这个网址包括各种类型的最大值
http://msdn.microsoft.com/en-us/library/7fh3a000(VS.80).aspx

如果是c++的话看这个:
#include <limits>
#include <stdio.h>
using namespace std;
int main(int,char**)
{
printf("%d",numeric_limits<int>::max());
return 0;
}

热心网友 时间:2022-03-26 10:28

1000 0000 0000 0000不是-0是-1
所以1000 0000 0000 0001是-2
而0000 0000 0000 0001是1
明白了?

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com