C/C++中有关字长与平台无关的整数类型

2018-08-07 14:39:58 浏览数 (1)

在C/C 中,整型的长度跟编译器相关,编译器的实现取决于CPU. 比如TC 是DOS16下的应用程序,DOS16是16位的操作系统,所以TC 中sizeof(int)==16;同理win32中sizeof(int)==32.

    C99标准定义一个叫着的头文件,该头文件定义了一系列各种类别的整数类型typedef名字。尽管速多C 工具支持该头文件已经有一段时间了,但它尚未正式收录于C 标准,因此,在使用该头文件之前,你应该先阅读你的编译器文档,看看它是否支持该文件。在某些C 的编译器中,如GNC,为了能使用C99标准的这些新特性,就在头文件中引入了这个文件< stdint.h>.

字长固定的整型类型

    C99标准在这个头文件的类型定义中,有一套是字长固定的整型类型:

    int8_t   int16_t   int32_t   int64_t

    与其对应的字长固定的无符号型整型类型有:

    uint8_t   uint16_t   uint32_t   uint64_t

    它们的名字非常直观。例如,int8_t是长度固定为8比特的有符号整型类型,而uint8_t则是字长固定为8比特的无符号型整型类型。当你需要确保在不同的平台上,整型数据的字长固定不变,那么你就可以使用这些typedef名字。允许对期望的性质进行更为详细的描述。例如,有的类型的名字是 int_least8_t,它至少有 8 位,还有 int32_t,它恰好是 32 位。

    C99标准标准保证至少可以访问 8 位、16 位、32 位和 64 位类型。没有保证会提供精确宽度类型。不要使用这种类型,除非您肯定是实在不能接受更大的类型。另一个可选的类型是新的 intptr_t 类型,它是一个足够大的可以容纳一个指针的整数。并不是所有的系统都提供这样一种类型(尽管当前所有的 Linux 和 BSD 实现都提供)。

字长最小的快速整型类型

    该头文件还定义了另外一套typedef名字,即“最小指定长度的快速整数类型”。这套typedef名字中的每一种都表示一种整数类型,它满足在长度不小于某个指定长度的前提下,拥有最快的处理速度。这些整数类型的名字为int_fastX_t(有符号)或者uint_fastX_t(无符号),其中“X”表示最小指定长度。例如,int_fast32_t指得是字长至少为32比特的快速有符号整型类型。最小字长快速整型类型有:

    int_fast8_t  int_fast16_t  int_fast32_t  int_fast64_t

    对应的无符号整型类型有:

    uint_fast8_t  uint_fast16_t  uint_fast32_t  uint_fast64_t

什么情况下使用这些typedef名字?

    假设你需要一个字长不少于16比特的循环计数器,那么你会希望该计数器的类型总是当前计算机CPU最佳操作的整型类型,而int_fast16_t可以保证任何平台上的编译器总是选择字长不少于16比特的最快整型类型。

代码语言:javascript复制
#include 
for (int_fast16_t n=0; n<30000;   n)
{
//.. do something
}

    关于整型参数移植

    假如你需要确定容量的整型,那么你应该使用stdint.h或者inttypes.h中定义的类型。

    这些头文件中定义了以下的整数类型:

代码语言:javascript复制
int8_t;
uint8_t;
int16_t;
uint16_t;
int32_t;
uint32_t;
int64_t;
uint64_t;
int_least8_t;
uint_least8_t;
int_least16_t;
uint_least16_t;
int_least32_t;
uint_least32_t;
int_least64_t;
uint_least64_t;
int_fast8_t;
uint_fast8_t;
int_fast16_t;
uint_fast16_t;
int_fast32_t;
uint_fast32_t;
int_fast64_t;
uint_fast64_t;
intptr_t;
uintptr_t;
intmax_t;
uintmax_t;

    如果是boost库的用户则比较幸运,因为在boost库中,这个头文件封装了C99标准中的整数类型.

ntp

0 人点赞