在std :: variant中访问公共结构成员

问题描述

我很难理解如何在C ++ 17中使用std::variant。给定两个结构AB,以及一个std::vector<std::variant<A,B>> vs,我想:

  • 请参考常见的struct成员,例如n;
  • 调用一个通用函数,例如fun()add()
#include <iostream>
#include <variant>
#include <vector>

struct A {
    int n;
    void fun() { std::cout << "fun\n"; }
    int add(int m) { return n+m; }
};
struct B {
    int n;
    void fun() { std::cout << "fun\n"; }
    int add(int m) { return n+m; }
};

int main() {
    std::vector<std::variant<A,B>> vs;
    vs.push_back(A{10,11});
    vs.push_back(B{20,22});
    
    // How to refer to struct members without using std::get<v.index()>(v)?
    for (auto && v : vs) {
         // 1. How to refer to v.n?
         // 2. How to call v.fun()?
         // 3. How to call v.add() with input parameter m?
    }
}

我被告知要使用std::visit,但太直率了,无法理解其工作原理。有人可以在这里显示一个简单的例子吗?

解决方法

std::visit与具有auto&&参数的lambda一起使用,以访问所有变量类型共有的成员。在您的示例中:

for (auto&& v : vs) {
    std::visit([&](auto&& x){
        std::cout << x.n << x.add(1);
        x.fun();
    },v);
}