Nel codice seguenteinferenza con rvalue initializer_list
#include <initializer_list>
#include <utility>
template<typename T> void f(T&& x) {}
template<typename T> void g(std::initializer_list<T> x) {}
int main()
{
auto x = {0}; // OK
auto&& y = {0}; // OK
g(x); // OK
g(std::move(x)); // OK
g({0}); // OK
f(x); // OK
f(std::move(x)); // OK
f({0}); // failure
return 0;
}
rvalue initializer_list
può dedurre con auto
ma non con template
.
Perché C++ lo proibisce?
Probabilmente perché '{0}' viene trattato come una sorta di "inizializzazione letterale" e intuitivamente si puo' t spostarsi da un valore letterale (o avere un riferimento di rvalue a uno da cui si potrebbe passare). –
Ti manca '#include', a proposito. –
chris
@chris - hai ragione. Modificherò –