int main() {
auto const fn = [] mutable {};
fn(); // ok, why?
}
< /code>
Согласно последнему стандартному проекту C ++ [expr.prim.lambda.closure] 7.5.6.2/6 < /em> (Mine Anthemis): < /p>
Оператор функции или шаблон оператора - это функция STATIC
или Static Semptate (11. /> Плаватор Lambda-Expression-положения следуют
static. В противном случае, это нестатическая функция члена или шаблон функции
(11.4.3) , которая объявляется const (11.4.3), если и только < /strong>
если параметры Lambda-Expression-declaration не является < /strong>
, за которым следует мутибельный < /strong> и lambda destarator, не содержит отмены. параметр.
Поскольку лямбда помечена как изменяющая
, затем:
его оператор () должен быть помечен как неконтролируемый.
Рассмотрим следующий код: < /p> [code]int main() { auto const fn = [] mutable {}; fn(); // ok, why? } < /code> Согласно последнему стандартному проекту C ++ [expr.prim.lambda.closure] 7.5.6.2/6 < /em> (Mine Anthemis): < /p>
Оператор функции или шаблон оператора - это функция STATIC или Static Semptate (11. /> Плаватор Lambda-Expression-положения следуют static. В противном случае, это нестатическая функция члена или шаблон функции (11.4.3) , которая объявляется const (11.4.3), если и только < /strong> если параметры Lambda-Expression-declaration не является < /strong> , за которым следует мутибельный < /strong> и lambda destarator, не содержит отмены. параметр.
Поскольку лямбда помечена как изменяющая [/code], затем: [list] [*] его оператор () должен быть помечен как неконтролируемый.[code]auto const fn[/code] означает fn является объектом const, поэтому fn не может вызвать неконфектный оператор () . [/list] Однако оба gcc & clang принимают код выше, см. Незаконная функция члена?