将int转换为指针时编译错误

时间:2012-10-25 03:43:43

标签: c++ c

我需要帮助解决我遇到的编译错误。

错误是: 错误:从不同大小的整数[-Werror = int-to-pointer-cast]

转换为指针

在以下一行

PRINT_INDENT("Inode2 PTR: %p\n", (void *)ptr);

上下文

unsigned int ptr;
memcpy(&ptr, value, sizeof(ptr));
PRINT_INDENT("Inode2 PTR: %p\n", (void *)ptr);

#define PRINT_INDENT(...) ({int __j = indent_level; while (__j-- > 0) printf("  "); printf(__VA_ARGS__);})

3 个答案:

答案 0 :(得分:2)

您使用的是32位int的64位平台吗?如果是这样,错误是不言自明的。 ptr是一个32位变量,您将其转换为64位void *。解决方法是首先将其转换为unsigned long long,然后将结果转换为void *

PRINT_INDENT("Inode2 PTR: %p\n", (void *)(unsigned long long)ptr);

但你为什么要这样做?为什么不将ptr打印为unsigned int而不是将其投放到void *,如下所示:

PRINT_INDENT("Inode2 PTR: %u\n", ptr);

答案 1 :(得分:1)

我不确定为什么需要将int转换为指针;如果目的只是打印指针,则可能没有必要。

但是,如果需要这种类型的转换,那么为了确保整数具有正确的大小,C ++ 11为无符号整数数据类型提供了一个别名,该类型足以容纳指针:< / p>

std::uintptr_t

cstdint标头中定义(对于C,C99标准也将uintptr_t定义为stdint.h

使用this作为整数类型(或者将现有的整数类型转换为此类 - 但请注意,如果原始类型较大,可能会丢失信息!)如果确实需要int / pointer强制转换,则是正确的方法。

请参阅相关问题:What is uintptr_t data type

答案 2 :(得分:0)

如果您想要执行此类操作,则应使用uintptr_t类型。它是C99和C ++ 11标准中相对较新的类型。

不能保证int足够大以容纳指针值,实际上在具有32位整数和64位指针的64位平台上它们不是。

memcpy(&ptr, value, sizeof(ptr));

如果value是指针,则该行仅复制其64位值的一半。