starałem się zrozumieć poniższy przykład, który dostałam od http://en.cppreference.com/w/cpp/utility/variant/visitUżywanie std :: odwiedzić ze zmiennej liczbie argumentów szablonu 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);
}
}
Może ktoś proszę wyjaśnić, jak to działa przeciążony struct? Szczególnie nie zrozumiałem poniższej deklaracji.
template<class... Ts> overloaded(Ts...) -> overloaded<Ts...>;
Bez tej deklaracji kompilator wydaje następujące komunikaty o błędach.
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
Cel: nauka
Istnieje [propozycja] (http://open-std.org/JTC1/SC22/WG21/docs/papers/2016/p0051r2.pdf), aby dodać coś takiego do standardowej biblioteki jako 'std :: overload' i [a 5-minutowe wideo] (https://www.youtube.com/watch?v=1gNzhE-Tn40&list=PLs3KjaCtOwSZ2tbuV1hx8Xz-rFZTan2J1&index=50) na temat implementacji tego. –