C++ 使用指针算术获取 parrent 类
C++ Getting parrent class with pointer arithmetic
在下面的代码中:
using Previous = std::atomic<void*>;
template<class T>
struct Element{
Previous previous;
T value;
}
我可以做指针算术来从T*
获得Element<T>*
吗? 喜欢这个:
template<class T>
Element<T>* getElement(T* value){
return static_cast<Element<T>*>(static_cast<void*>(reinterpret_cast<unsigned char *>(value) - sizeof(Previous)));
}
其中T
可能是非标准布局。
附言我清楚地看到我不能为此使用偏移量。但是,对于这种特殊情况,指针算术可能会起作用?
答案是:这取决于编译器!
如果您有一个 64 位编译器,并且sizeof(Previous)
为 4,T
是指针数据类型,则编译器(至少大多数编译器(将在previous
和value
之间添加 4 个额外的字节。
您获得的指针:
(void *)(((unsigned char *)value) - sizeof(Previous)
。在这种情况下,将指向previous
后的第一个字节!
但是,您可以将sizeof(Previous)
替换为以下表达式:
(int)&(((Element *)NULL)->value)
(抱歉,上面的表达式是 C 表达式;我的C++不是最好的。
此表达式应始终为常量:父结构中元素的地址偏移量。
编辑
从理论上讲,可能会有编译器执行NULL
指针检查,这在使用上述表达式时会导致错误。
在这种情况下,以下表达式将完成这项工作:
((int)&(x.value) - (int)&x)
。而x
是数据类型Element
的任何对象(例如局部变量(。
相关文章:
- C++为构建时间获取QDateTime的可靠方法
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 使用指针从C++中的数组中获取最大值
- 如何获取std::result_of函数的返回类型
- 如何在openssl-ecc中获取十六进制格式的私钥
- 使用Unreal C++获取VR耳机的世界位置/方向
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 从C字符串中获取奇怪的字符串长度
- 为什么我的for循环不能正确获取argv
- 从python中调用C++函数并获取返回值
- 如何获取一个数字的前3位
- 获取字符串的长度并将其分配给数组
- 无法获取菜单选择以运行函数.C++
- 数组长度,为什么从命令行获取时不能使用它?
- Boost Spirit,获取迭代器内部语义动作
- 尝试通过OCI例程从Oracle获取blob数据,但出现错误:ORA-01008:并非所有变量都绑定
- 具有默认值的引用获取函数
- xmake总是报告:错误:无法获取cxx的程序,为什么
- C++ 使用指针算术获取 parrent 类