无符号长的类型与Windows上的uint32_t和uint64_t不同(VS2010)

时间:2012-07-23 11:18:52

标签: c++ visual-c++ visual-c++-2010

在Windows 7,32位下的Visual Studio 2010上,unsigned long似乎是uint32_t和uint64_t的不同类型。请参阅以下测试程序:

#include <stdint.h>
#include <stdio.h>

template<class T, class U>
struct is_same_type
{
    static const bool value = false;
};
template<class T>
struct is_same_type<T, T>
{
    static const bool value = true;
};

#define TO_STRING(arg)        TO_STRING_IMPL(arg)
#define TO_STRING_IMPL(arg)   #arg

#define PRINT_SAME_TYPE(type1, type2) printf("%s (size=%d) %s %s (size=%d)\n", \
    TO_STRING(type1), int(sizeof(type1)), \
    is_same_type<type1, type2>::value ? "==" : "!=", \
    TO_STRING(type2), int(sizeof(type2)))


int main(int /*argc*/, const char* /*argv*/[])
{
    PRINT_SAME_TYPE(uint32_t, unsigned long);
    PRINT_SAME_TYPE(uint64_t, unsigned long);
    return 0;
}

我希望它能打印

uint32_t (size=4) != unsigned long (size=8)
uint64_t (size=8) == unsigned long (size=8)

(我在x86_64 Linux上获得)或

uint32_t (size=4) == unsigned long (size=4)
uint64_t (size=8) != unsigned long (size=4)

当然假设长度不超过64位。

然而,在Windows上,我感到莫名其妙

uint32_t (size=4) != unsigned long (size=4)
uint64_t (size=8) != unsigned long (size=4)

这意味着有两种不同的32位无符号类型。这是否允许C ++标准?或者这是Visual C ++编译器中的错误吗?

1 个答案:

答案 0 :(得分:6)

  

有两种截然不同的32位无符号类型

是的,有。 intlong都由32位表示。

  

这是否允许C ++标准?

是。规范陈述(C ++11§3.9.1[basic.fundamental] / 2):

  

有五种标准的有符号整数类型:signed charshort intintlong intlong long int。在此列表中,每种类型至少提供与列表中前面一样多的存储空间。

     

对于每个标准有符号整数类型,存在相应的(但不同的)标准无符号整数类型...每个类型占用相同的存储量并且具有与对应的有符号整数类型相同的对齐要求

请注意,尽管intlong由相同的位数表示,但它们仍然是不同的类型(因此,例如,在重载解析期间它们的处理方式不同)。 / p>