我需要帮助解决我遇到的编译错误。
错误是: 错误:从不同大小的整数[-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__);})
答案 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位值的一半。