像向量一样访问向量中结构元素的函数

Function to access element of struct in vector like a vector

我有一个结构向量:

struct vec_record {
unsigned int term;
unsigned int coef;
};
vector<vec_record> data;

出于某种原因,我只想对一个结构元素进行一些操作,然后对另一个结构元素进行相同的操作,但我希望它是分开的,所以我有功能:

void change(vector<unsigned int> &val) {
//some changes on data
}

如果我有两个向量,它将完美地工作:

vector<unsigned int> term;
vector<unsigned int> coef;
change(term);
change(coef);

但我希望能够这样做:

vector<vec_record> data;
change(data.term);    //not valid
change(data.coef);    //not valid

有没有办法获得这个功能? 也许使用 C++11 中的函数?

与其使用 AoS 方法,不如考虑使用 SoA:

struct vec_record {
    vector<int> term;
    vector<int> coef;
};

vec_record data;
change(data.term);
change(data.coef);

指向成员的指针是您在纯 C++ 中的解决方案:

void change(vector<vec_record> &data, unsigned int vec_record::*member) {
    for(auto &datum : data)
        std::cout << datum.*member << '\n'; // Accessing the member
}

这样调用:

change(data, &vec_record::term);

如果适用,您也可以通过非类型模板参数传递它们:

template <unsigned int vec_record::*Tmember>
void change(vector<vec_record> &data) {
    for(auto &datum : data)
        std::cout << datum.*Tmember << '\n'; // Accessing the member
}

这样调用:

change<&vec_record::term>(data);