W this article poniższy kod prezentuje:Compiler-wywnioskować typ dla lambdas generycznych
std::vector<int> ivec = { 1, 2, 3, 4};
std::vector<std::string> svec = { "red", "green", "blue" };
auto adder = [](auto op1, auto op2){ return op1 + op2; };
std::cout << "int result : "
<< std::accumulate(ivec.begin(),
ivec.end(),
0,
adder)
<< "\n";
std::cout << "string result : "
<< std::accumulate(svec.begin(),
svec.end(),
std::string(""),
adder)
<< "\n";
Jeśli dobrze rozumiem, kompilator wygeneruje klasę wewnętrzną dużo jak ten:
template<class T>
class _lambda
{
public:
T operator()(T lhs, T rhs) { return lhs + rhs; }
};
Ale nie rozumiem, że w tej części kodu adder wydaje się mieć dwa typy w tym samym czasie: _lambda<int>
i _lambda<string>
. Jak to jest możliwe?
Podobnie, jeśli argumenty są podobne 'auto && lhs'. następnie generuje 'T && lhs' .. i tak dalej. – Nawaz