字长与平台无关的整型数据类型
在C/C++中,整型的长度跟编译器相关,编译器的实现取决于CPU。 比如TC++是DOS16下的应用程序,DOS16是16位的操作系统,所以TC++中sizeof(int)==16;同理win32中sizeof(int)==32。
C99标准定义一个叫着
字长固定的整型类型
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比特的最快整型类型。
#include
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库中,
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/roger_77/archive/2006/04/13/661859.aspx