除了之外,标准没有关于任何整数类型的确切大小
char。通常,
long在32位系统上为32位,在64位系统上为64位。
但是,该标准并未指定 最小 尺寸。从C标准的 5.2.4.2.1节开始:
1
以下给出的值应被适合用于#if预处理指令的常量表达式代替。此外,除了CHAR_BIT和之外MB_LEN_MAX,以下内容应替换为与根据整数提升转换为相应类型的对象的表达式具有相同类型的表达式。
其实现定义的值的大小(绝对值)应等于或大于所示的相同符号。…
- 类型对象的最小值
long intLONG_MIN-2147483647 //-(2 ^ 31-1)
- 类型对象的最大值
long intLONG_MAX+2147483647 // 2 ^ 31−1
这表示a
long int必须 至少为32位,但可能更大。在
CHAR_BIT值为8
的机器上,它的最小字节大小为4。但是,在例如
CHAR_BIT等于16的机器上,a
long int可以为2个字节长。
这是一个真实的例子。对于以下代码:
#include <stdio.h>int main (){ printf("sizeof(long) = %zun", sizeof(long)); return 0;}
在Debian 7 i686上的输出:
sizeof(long)= 4
在CentOS 7 x64上的输出:
sizeof(long)= 8
因此,您不能对大小做任何假设。如果需要特定大小的类型,可以使用中定义的类型
stdint.h。它定义了以下类型:
int8_t
:签名的8位uint8_t
:无符号8位int16_t
:有符号16位uint16_t
:无符号16位int32_t
:有符号32位uint32_t
:无符号32位int64_t
:签名的64位uint64_t
:无符号64位
所述
stdint.h报头在标准的第7.20节中描述7.20.1.1,具有精确宽度的类型。该标准指出,这些typedef是可选的,但它们存在于大多数实现中。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)