施放INT指针时编译错误
compile error when casting an int to pointer
我需要帮助我遇到的编译错误。
错误是:错误:从不同大小的整数[-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数据类型
相关文章:
- std::is_base_of表示ctor编译错误
- Qt5:使用QCommandLineParser类时出现奇怪的编译错误
- 如何修复sfml c++代码编译错误
- 使用 MATLAB 编码器生成C++代码:编译错误"undefined reference to `rgb2gray_tbb_real64'"
- 使用外部SDK工具链文件在VisualStudio上生成项目编译错误
- vscode下的Arduino代码出现意外编译错误
- 第三方 API 中的编译错误 - Visual Studio
- std::cout输出int时出现编译错误
- 奇怪的代码抛出编译错误模板< J,int aSize=10> C2143:语法错误:在"<"之前缺少";"
- 提升图广度优先搜索前置编译错误
- C++ 中的编译错误:未定义对"主"的引用 collect2:错误:ld 返回 1 个退出状态
- 使用带有 ref 参数的成员函数创建线程时出现编译错误
- 我在C++中遇到了这个奇怪的编译错误
- 在C++中使用 Catch 测试框架编译错误"error: expected ';' at end of declaration list"
- 使用 std::enable_if 限制派生类的模板参数时出现编译错误
- 现代OpenGL和GLEW Libraray的编译错误
- C++ 编译错误:意外的类型名称"字符串":预期的表达式
- C ++程序编译错误,找不到/访问文件
- 使用直接大括号初始化时,C++ 编译错误"声明末尾的预期";"
- 为什么传递非静态成员函数会导致编译错误?