If you have this function
template<typename T> f(T&);
And then try to call it with, let’s say an rvalue like
f(1);
Why isn’t T just be deduced to be const int, making the argument a const int& and thus bindable to an rvalue?
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
This is mentioned as a potential solution in the document I linked in the recent C++0x forwarding question.
It would work fairly well, but it breaks existing code. Consider (straight from the document):
Or
This also fails to forward the value category (lvalue or rvalue), which isn’t much of a problem in C++03. But since this fix could only be done during C++0x, we’d effectively shutting ourselves out from rvalue references when forwarding (a bad thing). We should strive for a better solution.