我最近在一个 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
或 { 1} -- 后者(如果它们存在的话)可能来自其他一些头文件或库(很可能早于 C99 中添加的 int8_t
和 int32_t
)。
普通的 int
与其他的有很大不同。其中 int8_t
和 int32_t
各有一个指定的大小,int
可以是任何大小 >= 16 位。在不同的时间,16 位和 32 位都相当普遍(对于 64 位实现,它可能应该是 64 位)。
另一方面,int
保证出现在 C 的每个实现中,而 int8_t
和 int32_t
不存在。不过,这对您是否重要可能还有待商榷。如果您在小型嵌入式系统和/或较旧的编译器上使用 C,则可能会出现问题。如果你主要在桌面/服务器机器上使用现代编译器,它可能不会。
糟糕——错过了关于 char
的部分。如果(且仅当)您希望整数类型保证为 8 位大小时,您将使用 int8_t
而不是 char。如果你想存储字符,你可能想用 char
代替。它的大小可能会有所不同(就位数而言),但可以保证恰好是一个字节。不过有一点奇怪:无法保证普通的 char
是有符号还是无符号(许多编译器可以将其设为其中之一,具体取决于编译时标志)。如果您需要确保其被签名或未签名,则需要明确指定。
_t 数据类型是 stdint.h 标头中的 typedef 类型,而 int 是内置的基本数据类型。这使得 _t 仅在 stdint.h 存在时可用。另一方面, int 保证存在。
请始终记住,如果未明确指定,“大小”是可变的,因此如果您声明
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
。
bool_t
——以前从未听说过那个。 C 标准将_Bool
定义为内置类型。bool
仅在您使用#include <stdbool.h>
时才被定义(作为扩展为_Bool
的宏)。