ich das folgende Beispiel zu verstehen versuchte, die ich von http://en.cppreference.com/w/cpp/utility/variant/visit bekamMit std :: besuchen mit variadische template struct
#include <iomanip>
#include <iostream>
#include <string>
#include <type_traits>
#include <variant>
#include <vector>
using var_t = std::variant<int, long, double, std::string>;
template<class... Ts> struct overloaded : Ts... { using Ts::operator()...; };
// what is this declaration imply???
template<class... Ts> overloaded(Ts...) -> overloaded<Ts...>;
int main() {
std::vector<var_t> vec = {10, 15l, 1.5, "hello"};
for (auto& v: vec) {
std::visit(overloaded {
[](auto arg) { std::cout << arg << '\n'; },
[](double arg) { std::cout << std::fixed << arg << '\n'; },
[](const std::string& arg) { std::cout << std::quoted(arg) << '\n'; },
}, v);
}
}
Kann jemand bitte erklären, wie diese Struktur Arbeiten überlastet? Vor allem, was ich nicht verstanden habe, ist die folgende Erklärung.
template<class... Ts> overloaded(Ts...) -> overloaded<Ts...>;
Ohne diese Deklaration gibt der Compiler die folgenden Fehlermeldungen aus.
main.cpp: In function 'int main()':
main.cpp:26:9: error: class template argument deduction failed:
}, v);
^
main.cpp:26: confused by earlier errors, bailing out
Zweck: Lernen
Es ist [ein Vorschlag] (http://open-std.org/JTC1/SC22/WG21/docs/papers/2016/p0051r2.pdf), so etwas zu der Standardbibliothek als 'std hinzufügen :: overload' und [ein 5-minütige Video] (https://www.youtube.com/watch?v=1gNzhE-Tn40&list=PLs3KjaCtOwSZ2tbuV1hx8Xz-rFZTan2J1&index=50) über diese umzusetzen. –