Ich habe eine std::variant
, die ich in eine andere std::variant
konvertieren möchte, die eine Super-Reihe seiner Typen hat. Gibt es eine Möglichkeit, das zu tun, als dass ich es einfach dem anderen zuweisen kann?Convert std :: Variante in eine andere Std :: Variante mit Super-Satz von Typen
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;
}
Ich mag würde die Lage sein, einfach b = a
zu schreiben, um die Umwandlung eher zu tun, als durch diesen komplexen Guss Setup gehen. Ohne den Namensraum std
zu verschmutzen.
Edit: Einfach b = a
Schreiben gibt den folgenden Fehler:
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>)'
Wenn 'U' ist Universum aller Typen und P hat U, ist nicht P gleich U? Ich habe Probleme zu verstehen, welches Problem Sie versuchen zu lösen, vielleicht bin ich dumm: | – P0W
Versuchen Sie, 'b = a' direkt zu kompilieren, um das Problem zu sehen. –
Der Fehler lautet wie folgt: Fehler C2679: binäre '=': kein Operator gefunden, die einen rechten Operanden vom Typ 'Std :: Variante' (oder es gibt keine akzeptable Konvertierung) Hinweis: beim Versuch zu passe die Argumentliste an (std :: variant , std :: variant ) ' –
Bomaz