由rvalue指定的三元表达式不使用移动分配运算符

Kan*_* Li 11 c++ gcc c++11

任何人都知道为什么以下代码无法编译:

[hidden]$ g++ -v |& tail -n 1
gcc version 4.8.1 20130603 (Red Hat 4.8.1-1) (GCC)
[hidden]$ cat c.cpp
struct X {
  X() = default;
  X(const X&) = default;
  X(X&&) = default;
  X& operator=(const X&) = delete;
  X& operator=(X&&) = default;
};

void f(bool t) {
  X a, b;
  (t ? a : b) = X();
}

[hidden]$ g++ -std=c++11 -c c.cpp
c.cpp: In function ‘void f(bool)’:
c.cpp:11:15: error: use of deleted function ‘X& X::operator=(const X&)’
   (t ? a : b) = X();
               ^
c.cpp:5:6: error: declared here
   X& operator=(const X&) = delete;
      ^
c.cpp:11:15: error: use of deleted function ‘X& X::operator=(const X&)’
   (t ? a : b) = X();
               ^
c.cpp:5:6: error: declared here
   X& operator=(const X&) = delete;
      ^
Run Code Online (Sandbox Code Playgroud)

这不是X()rvalue所以在这种情况下应该调用移动赋值运算符吗?C++ 11标准中的哪一节讨论了由rvalue分配的案例三元表达式?

注意:在这种情况下,三元表达式是左值,因为如果我改变了= deleteto = default,它就会编译.

Ali*_*Ali 2

这是编译器中的一个错误,请参阅对条件赋值中的赋值运算符的虚假重载解析,它在 gcc 4.9 中仍然失败。

问题不在于三元运算符,而在于重载决策以错误的赋值运算符结束。