施放INT指针时编译错误

compile error when casting an int to pointer

本文关键字:编译 错误 指针 INT 施放      更新时间:2023-10-16

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

错误是:错误:从不同大小的整数[-werror = int-to-pointer-cast]铸造到指针

在以下行

PRINT_INDENT("Inode2 PTR: %pn", (void *)ptr);

上下文

unsigned int ptr;
memcpy(&ptr, value, sizeof(ptr));
PRINT_INDENT("Inode2 PTR: %pn", (void *)ptr);
#define PRINT_INDENT(...) ({int __j = indent_level; while (__j-- > 0) printf("  "); printf(__VA_ARGS__);})

您是否使用具有32位int s的64位平台?如果是这样,则错误是自称的。ptr是一个32位变量,您将其投入到64位void *。解决方法是首先将其施加到unsigned long long,然后将结果施加到void *

PRINT_INDENT("Inode2 PTR: %pn", (void *)(unsigned long long)ptr);

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

PRINT_INDENT("Inode2 PTR: %un", ptr);

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

不能保证INT足够大以保持指针值,并且确实在具有32位INT和64位指针的64位平台上。

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

如果value是指针,此行只能复制其64位值的一半。

我不确定为什么您需要将INT投入指针;如果目的只是打印指针,则可能无需。

但是,如果需要这种铸件,则为了确保整数具有正确的尺寸,C 11为无符号整数数据类型提供了一个别名,该数据类型足够大,可以容纳指针:

std::uintptr_t

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

将其用作整数类型(或将现有的整数类型施放到此;中,请注意,如果真正需要INT/Pointer casts,则可能会丢失信息。)是正确的方法。

请参阅相关问题:什么是uintptr_t数据类型