我最近在一个C程序中遇到了数据类型int32_t
。我知道它存储32位,但是int
和int32
不是也一样吗?
另外,我想在程序中使用char
。我可以用int8_t
代替吗?它们之间有什么区别?
总结一下:C语言中int32、int、int32_t、int8和int8_t有何不同?
我最近在一个C程序中遇到了数据类型int32_t
。我知道它存储32位,但是int
和int32
不是也一样吗?
另外,我想在程序中使用char
。我可以用int8_t
代替吗?它们之间有什么区别?
总结一下:C语言中int32、int、int32_t、int8和int8_t有何不同?
int32
和 int32_t
之间(同样地,在 int8
和 int8_t
之间),它们的区别非常简单:C 标准定义了 int8_t
和 int32_t
,但没有定义任何名为 int8
或 int32
的类型 -- 后者(如果它们存在的话)可能来自于其他头文件或库(很可能早于 C99 中添加的 int8_t
和 int32_t
)。int
与其他类型有很大不同。虽然每个 int8_t
和 int32_t
都有一个指定的大小,但是 int
可以是任何大小>=16位。在不同的时间里,16 位和 32 位都是相当普遍的(对于 64 位实现,应该是 64 位)。int
在每个 C 实现中都保证存在,而 int8_t
和 int32_t
不保证存在。但这是否对您有影响仍需讨论。如果在小型嵌入式系统上和/或使用旧编译器,则可能会有问题。如果主要在桌面/服务器机器上使用现代编译器,则可能不会有问题。哎呀——我漏掉了关于char
的部分。如果(只有当)您需要一个确切大小为8位的整数类型,那么您应该使用int8_t
而不是char
。如果您想存储字符,您可能想要使用char
。它的大小可以变化(按位数计算),但其大小保证为一个字节。但是有一个小小的怪异之处:不能保证普通的char
是带符号还是无符号的(许多编译器可以根据编译时标志将其设置为任意一种)。如果您需要确保它是带符号或无符号的,您需要明确指定。
_t数据类型是在stdint.h头文件中的typedef类型,而int是一个内置的基本数据类型。这意味着只有在存在stdint.h头文件时,_t才可用。另一方面,保证int存在。
请始终记住,如果没有明确指定,'size'是可变的。因此,如果您声明
int i = 10;
在一些系统中,编译器可能会产生16位整数,在另一些系统中可能会得到32位整数(在新的系统上可能是64位整数)。
在嵌入式环境中,这可能会导致奇怪的结果(特别是在处理内存映射I/O或考虑简单的数组情况时),因此强烈建议指定固定大小的变量。在旧系统中,你可能会遇到
typedef short INT16;
typedef int INT32;
typedef long INT64;
从C99开始,设计者增加了stdint.h头文件,该头文件可以利用类似的typedef。
在基于Windows的系统上,您可能会看到stdin.h头文件中的条目如下:
typedef signed char int8_t;
typedef signed short int16_t;
typedef signed int int32_t;
typedef unsigned char uint8_t;
还有一些其他类型,例如最小宽度整型或精确宽度整型等,我认为探索stdint.h可以更好地理解。
typedef short INT16;
而不是typedefs short INT16
。请注意修正。 - Galaxy
bool_t
是什么——以前从未听说过。C标准将_Bool
定义为内置类型。只有在您包含<stdbool.h>
(作为扩展到_Bool
的宏)时,才会定义bool
。 - Jerry Coffin