C/C++中有关字长与平台无关的整数类型
C99标准定义一个叫着<stdint.h>的头文件,该头文件定义了一系列各种类别的整数类型typedef名字。尽管速多C++工具支持该头文件已经有一段时间了,但它尚未正式收录于C++标准,因此,在使用该头文件之前,你应该先阅读你的编译器文档,看看它是否支持该文件。在某些C++ 的编译器中,如GNC,为了能使用C99标准的这些新特性,就在<inttypes.h>头文件中引入了这个文件< stdint.h>.
字长固定的整型类型
C99标准在<stdint.h>这个头文件的类型定义中,有一套是字长固定的整型类型:
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比特的最快整型类型。
#include <inttypes.h> for (int_fast16_t n=0; n<30000; ++n) { //.. do something } |
关于整型参数移植
假如你需要确定容量的整型,那么你应该使用stdint.h或者inttypes.h中定义的类型。
这些头文件中定义了以下的整数类型:
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库中,<cstdint.hpp>这个头文件封装了C99标准<stdint.h>中的整数类型.