如何简化std :: variant类类型

时间:2018-10-08 19:17:17

标签: c++ c++17 variant std-variant

我确信有一个简单的方法可以做到这一点,但是在SO中找不到任何东西。 在en.cppreference.com中也找不到太多信息。

有没有一种方法可以简化std::variant</*class types*/>,以便我们可以声明可以将相同的std::variant作为参数的函数和类。

考虑以下示例:

我有一个向量,充当以下std::variant的容器;

std::vector<std::variant<Car, Space, Human>> EntityContainer;

如果我想将此向量作为参数传递给函数,则必须添加以下参数声明。

void Function(std::vector <std::variant<Car, Space, Human>>& container);

在这个示例中,我也许可以使用 macros ,但这并不能真正解决问题。

是否有更好的解决方案,而不是在项目各处各处std::variant中一遍又一遍地列出相同的类类型?

code live

#include <iostream>
#include <vector>
#include <variant>


class Human
{
public:
  void Talk(){ std::cout << "whass up\n"; }
};
class Car
{
public:
  void RunEngine() { std::cout << "Vroom\n"; }
};
class Space
{
public:
  void Expand() { std::cout << "Expand slowly\n"; }
};

struct VisitPackage
{
  void operator()(Human& obj) { obj.Talk();}
  void operator()(Car& obj) { obj.RunEngine();}
  void operator()(Space& obj) { obj.Expand();}
};  

void Function(std::vector <std::variant<Car, Space, Human>>& container)
{
  for (auto& entity : container)
  {
    std::visit(VisitPackage(), entity);
  }
}
int main()
{
  std::vector<std::variant<Car, Space, Human>> EntityContainer;
  EntityContainer.emplace_back(Car());
  EntityContainer.emplace_back(Human());
  EntityContainer.emplace_back(Space());
  Function(EntityContainer);

  return 0;
}

1 个答案:

答案 0 :(得分:3)

您要定义别名。可以使用usingtypedef来完成。 using因其语法而对C ++程序员更为熟悉,typedef与C兼容。

typedef std::variant<int, double, float> arithmetic;
using arithmetic = std::variant<int, double, float>;
//Both are equivalent

std::vector<arithmetic> entityContainer;
void function(std::vector<arithmetic> const& vector) {
    /*...*/
}