取以下成员函数:
struct T {
template <typename X> void f(X&& x) { /* ... */ }
};
在这种情况下,x
是一个转发引用,因为&&
它用于模板内的函数参数。这正如预期的那样。
现在使用这个函数:
struct T {
template <typename X> void f(X&& x) && { /* ... */ }
};
我希望this
会以类似的方式对待它;作为转发参考。因此,我希望以下程序能够正常编译和运行:
#include <iostream>
struct T {
template <typename X>
bool operator<(X&& rhs) && {
std::cout << "&&" << std::endl;
return true;
}
};
int main() {
T t;
std::cout << (t < T()) << std::endl;
return 0;
}
但是使用 GCC 4.8.4 和 6.0.1,它不会。相反,我得到以下信息:
rvalue.cpp: In function ‘int main()’:
rvalue.cpp:13:25: error: passing ‘T’ as ‘this’ argument of ‘bool T::operator<(X&&) && [with X = T]’ discards qualifiers [-fpermissive]
std::cout << (t < T()) << std::endl;
似乎this
没有进行转发参考。这是正确的还是错误的?是否应该this
被视为转发参考?标准的哪一部分规定了这一点?