我最近在C程序中遇到了数据类型int32_t
。我知道它存储了32位,但int
和int32
不是这样做的吗?
另外,我想在程序中使用char
。我可以使用int8_t
吗?有什么区别?
总结一下: C中的int32,int,int32_t,int8和int8_t有什么区别?
答案 0 :(得分:102)
在int32
和int32_t
之间(同样在int8
和int8_t
之间)差异非常简单:C标准定义int8_t
和{{ 1}},但没有定义任何名为int32_t
或int8
的东西 - 后者(如果它们一直存在)可能来自其他一些标题或库(很可能早于添加{{1} C99中的}和int32
。
普通int8_t
与其他人有点不同。如果int32_t
和int
各自具有指定的大小,int8_t
可以是任意大小> = 16位。在不同的时间,16位和32位都相当普遍(对于64位实现,它应该是64位)。
另一方面,int32_t
保证在C的每个实现中都存在,int
和int
不是。尽管如此,这对您是否重要仍有待商榷。如果在小型嵌入式系统和/或较旧的编译器上使用C,则可能存在问题。如果您主要使用桌面/服务器计算机上的现代编译器,它可能不会。
哎呀 - 错过了关于int8_t
的部分。如果(并且仅当)您希望保证整数类型的大小恰好为8位,则使用int32_t
而不是char。如果要存储字符,可能需要使用char
。它的大小可以变化(就位数而言)但它保证恰好是一个字节。但有一点奇怪的是:无法保证普通int8_t
是有符号还是无符号(并且许多编译器可以使它成为一个,具体取决于编译时标志)。如果您需要确保其已签名或未签名,则需要明确指定。
答案 1 :(得分:13)
_t数据类型是stdint.h头文件中的typedef类型,而int是构建的基本数据类型。这使得_t仅在stdint.h存在时可用。另一方面,int保证存在。
答案 2 :(得分:2)
始终牢记'尺寸'如果没有明确指定,则是变量,因此如果声明
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以获得更好的理解并不是一件坏事。