首页 > 解决方案 > 是否可以对结构进行分组以与 std::variant 一起使用

问题描述

我正在设计一个类来表示来自 10 多个来源的数据,使用std::variant. 每个源可能有 10 个不同的消息,因此该变体将代表 100 个不同的底层结构。

可以理解的是,我想在声明中声明std::variant没有列出 100 种类型:

std::variant<Type1, Type2, Type3............................ Type100>

我更喜欢对每个“源”的 10 个结构进行分组,并由variant组组成:

std::variant<Source1Types, Source2Types.... Source10Types>

有没有办法对结构进行分组,以便与 一起使用std::variant?如果没有,还有其他方法可以实现吗?

(我使用的是 C++20)

标签: c++c++20variant

解决方案


你可能会这样做:

using Source0Types = std::variant<Type0, Type1, Type2, Type3, .., Type9>;
using Source1Types = std::variant<Type10, Type11, Type12, Type13, .., Type19>;
// ..

using SourceTypeVariant = std::variant<Source0Types, Source1Types, .., Source9Types>;

这里需要注意的是,您有两个级别的变体(用于访问)。

您可以创建特征来展平/连接变体:

template <typename ... Vs> struct concatenate;
template <typename ... Vs> using concatenate_t = typename concatenate<Vs...>::type;

template <typename ... Ts> struct concatenate<std::variant<Ts...>>
{
    using type = std::variant<Ts...>;
};

template <typename ... Ts, typename ... Us, typename ... Vs>
struct concatenate<std::variant<Ts...>, std::variant<Us...>, Vs...> :
    concatenate<std::variant<Ts..., Us...>, Vs...>
{
};

所以

using MegaVariant = concatenate_t<Source0Types, Source1Types, .., Source9Types>;

推荐阅读