带有std::vector的offset函数

Offsetof Function with std::vector

本文关键字:offset 函数 vector std 带有      更新时间:2023-10-16

有人能向我解释一下为什么offsetof函数不能在std::vector上工作,如下所示:

#include <windows.h>
#include <iostream>
#include <vector>
using namespace std;
struct FooStruct {
    double x;
    double y[10];
    std::vector<double> z;
};
int main() {
    cout << offsetof(FooStruct, x) << endl;
    cout << offsetof(FooStruct, y[2]) << endl;
    cout << offsetof(FooStruct, z[2]) << endl;
    system("Pause");
}

调用offsetof(FooStruct, z[2])会产生以下编译错误:

cannot apply 'offsetof' when 'operator[]' is overloaded

offsetof(FooStruct, z[2])没有意义。z的元素不包含在FooStruct中,它们通过std::vector访问,CC_7的核心是指向堆上其他分配的指针,z[2]可以在其中找到。

在任何情况下,错误(我理解这似乎令人困惑)可能是因为std::vector重载operator[]而弹出,而不是因为你的class FooStruct重载operator[](假设我们看到整个定义,它没有)。

如果你想找到z[2]相对于z[0]的偏移量,你可以像这样计算&z[0]&z[2]之间的差值:

因为offsetof不是一个函数,而是一个宏,并且只适用于POD类型,或c++ 11中的标准布局类。它的存在只是为了向后兼容c。

编译器不允许使用订阅操作符的原因是,宏是在编译时求值的,但是重载的操作符可能会在运行时做一些工作来计算结果。