c++ - 将 std::variant 转换为另一个具有父类(super class)型集的 std::variant

标签 c++ type-conversion c++17 variant

我有一个 std::variant,我想将其转换为另一个具有其类型超集的 std::variant。有没有一种方法可以让我简单地将一个分配给另一个?

template <typename ToVariant, typename FromVariant>
ToVariant ConvertVariant(const FromVariant& from) {
    ToVariant to = std::visit([](auto&& arg) -> ToVariant {return arg ; }, from);
    return to;
}

int main()
{
    std::variant<int , double> a;
    a = 5;
    std::variant <std::string, double, int> b;
    b = ConvertVariant<decltype(b),decltype(a)>(a);
    return 0;
}

我希望能够简单地编写 b = a 来进行转换,而不是通过这种复杂的转换设置。不会污染 std 命名空间。

编辑:简单地写 b = a 会产生以下错误:

error C2679: binary '=': no operator found which takes a right-hand operand of type 'std::variant<int,double>' (or there is no acceptable conversion) 

note: while trying to match the argument list '(std::variant<std::string,int,double>, std::variant<int,double>)'

最佳答案

这是 Yakk 的第二个选项的实现:

template <class... Args>
struct variant_cast_proxy
{
    std::variant<Args...> v;

    template <class... ToArgs>
    operator std::variant<ToArgs...>() const
    {
        return std::visit([](auto&& arg) -> std::variant<ToArgs...> { return arg ; },
                          v);
    }
};

template <class... Args>
auto variant_cast(const std::variant<Args...>& v) -> variant_cast_proxy<Args...>
{
    return {v};
}

您可能希望针对转发语义对其进行微调。

如您所见,它的使用很简单:

std::variant<int, char> v1 = 24;
std::variant<int, char, bool> v2;

v2 = variant_cast(v1);

关于c++ - 将 std::variant 转换为另一个具有父类(super class)型集的 std::variant,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47203255/

相关文章:

c - C 中的类型提升和类型转换

c++ - 明确论证?

c++ - 在 C++ 中播放声音

c++ - 通过参数将字符串文字作为 char* 传递

c++ - VS2011代码分析

c++ - 如何将std::pair对的迭代器传递给函数模板,并推导迭代器类型?

Java <-> Scala 转换 - "value is not a member of"

python - qPython - kdb响应数据的类型转换

c++ - 为什么 std::swap 不能在 Clang/Win 下的 vector<bool> 元素上工作?

c++ - 函数的模板推导如何在 C++ 中工作?