ошибка одна и та же во всех 3 основных компиляторах :)
добавь перегрузку get для X&&
@mostvexingparsse верно написал про перегрузку get<> для && https://timsong-cpp.github.io/cppwp/n4868/dcl.struct.bind#4 In either case, e is an lvalue if the type of the entity e is an lvalue reference and an xvalue otherwise.
это понятно, что workaround. Но какие qualifiers discarded? Явно же бредовое сообщение об ошибке. Почему const float не конструируется из float&?
Это не воркэраунд, как я понимаю. a и b в вашем примере — это элиасы не для полей x (который lvalue), а для полей копии x, в стандарте называемой e (и которая в этом случае xvalue).
т.е. это должно сломаться, если у меня данные-члены non-copyable?
Вот как цппинсайт интерпретирует AST кланга: https://cppinsights.io/s/1c92b80e
Минимизированный пример: const std::tuple<int, int> t; auto [a, b] = t;
И вот так получится #include <tuple> int main() { const std::tuple<int, int> t = std::tuple<int, int>(); std::tuple<int, int> __t6 = std::tuple<int, int>(t); int && a = std::get<0UL>(static_cast<std::tuple<int, int> &&>(__t6)); int && b = std::get<1UL>(static_cast<std::tuple<int, int> &&>(__t6)); return 0; }
чёт не соответствует сообщению об ошибке. Нет таких слов в нём
Есть, просто неочевидно сформулировано. binding reference of type '...' {aka 'double&'} to 'const double' discards qualifiers
const double = double & — (псевдокод) вот такую ситуацию описывает сообщение об ошибке
сообщение описывает вот такую ситуацию: https://godbolt.org/z/crxr1hjoj
да уж. Путница. Тем более это не соответствует cppinsight выкладкам(
что чему не соответствует?
там double&& a = get...
Тип a зависит от value category инициализатора, которая в свою очередь определяется тем, какая перегрузка get<> выбрана. А это в свою очередь зависит от value category e (xvalue, если у вас auto [a, b], а не auto& [a, b], например) и от того, какие перегрузки есть (у вас нет для &&, но есть для const&). В том же пункте стандарта: Given the type Ti designated by std::tuple_element<i, E>::type and the type Ui designated by either Ti& or Ti&&, where Ui is an lvalue reference if the initializer is an lvalue and an rvalue reference otherwise, variables are introduced with unique names ri as follows: S Ui ri = initializer ;
а как код помечать что это именно с++?
Зачем ты постоянно пытаешься сохранить ссылки на временный объект? Может всё же если копируешь, то по значению?
я? это вообще псевдокод отсюда
Обсуждают сегодня