Что означает "идентичность" в определении категорий значений в C++

Короче говоря, вы можете просто ответить на часть о личности, спасибо. Мой основной вопрос в этом вопросе - начать с 2. о личности, я просто попытался представить контекст / основу моего текущего понимания, чтобы он мог помочь вам определить глубину, когда вы пишете свой ответ.


Я хочу понять общую картину системы типов и категорий значений в C++. Я искал / читал много вопросов и ресурсов в Интернете, но у каждого есть четкое объяснение, поэтому я действительно запутался. Я перечислю часть, которую я не могу понять, если бы кто-нибудь мог дать представление о

  1. На cppreference.com первая строка:

    У объектов, ссылок, функций, в том числе специализаций шаблонов функций, и выражений есть свойство, называемое типом, которое ограничивает операции, разрешенные для этих объектов, и обеспечивает семантическое значение для других общих последовательностей битов.

    мой вопрос:

    • Что значит выражение имеет тип? Это тип конечного результата после оценки?
    • Я не хочу изучать шаблон на данном этапе, будет ли это мешать изучению основной части (с точки зрения вашего эксперта)? Мне потребовалось некоторое время, чтобы понять, что ссылка для пересылки и ссылка на rvalue - это разные вещи, которые для шаблона являются первыми.
  2. Ценовые категории:

    Я прочитал этот ответ: что такое rvalues, lvalues, xvalues, glvalues ​​и prvalues? Фраза, которая меня беспокоит, это тождество, которое также появляется на cppreference.com - Value values ​​(Строка 5, glvalue).

    мой вопрос: могу ли я сказать, что identity == все, что я могу присвоить ему новое значение?

    • Я видел людей, использующих слово адрес / указатель для него, но это то, что has identity iff has address/pointer? Я хочу точный термин.
    • Я столкнулся с идеей битового поля при чтении cppreference.com, кажется, что дана структура битового поля a, его битовое поле a.m не имеет адреса? Это причина, по которой слово тождество используется вместо адреса / указателя?
    • Я нашел сообщение в блоге, объясняющее это, но его определение lvalue нелогично: lvalue обозначает объект, ресурс которого нельзя использовать повторно, почему бы и нет?

3 ответа

Решение
  1. Тип выражения - это тип его результата, если и когда выражение было оценено. Выражение не должно быть оценено, но все выражения имеют тип. Тип является статическим свойством.
  2. Там нет точного определения идентичности или указания, какие объекты имеют или не имеют идентичность. Это грязная концепция, которую лучше оставить в покое. Игнорируй это. Некоторые люди говорят, что идентификация объекта - это его адрес, но тогда эта концепция бесполезна. Почему бы тогда не поговорить о его адресе? А как насчет битовых полей? Это объекты без адресов, у них нет идентичности? Другие говорят, что lvalues ​​имеют идентичность, а rvalues ​​- нет, но тогда это так же избыточно.

identity это философская концепция. Это свойство вещи, которая делает его уникальным. никакие две "вещи" не могут иметь одинаковую идентичность.

То, что имеет идентичность, является сущностью.

[basic.lval]:

Glvalue - это выражение, оценка которого определяет идентичность объекта, битового поля или функции.

Имя внутри выражения может обозначать только один объект. Так что имя внутри выражения - это тождество. Он определяется как lvalue (например, см. http://eel.is/c++draft/expr.prim.id.unqual)

По данному адресу и в данное время не может быть 2 объектов одного типа (могут быть объекты, вложенные друг в друга,...). Таким образом, разыменование указателя дает lvalue.

Ссылка всегда обозначает сущность. Таким образом, каждая функция, которая возвращает ссылку при вызове, генерирует glvalue.

...

Значение x - это тег, который может быть сгенерирован только посредством приведения (или привязки к временной материализации). Это glvalue, который обозначает объект или битовое поле, ресурсы которого могут быть повторно использованы basic.lval

Разница между xvalue и lvalue используется для создания эффективного кода. Но xvalue как lvalue - это glvalue: они несут идентичность сущности.

...

Значение prvalue является результатом выражения, которое не связано ни с одним объектом. Это когда функция возвращается как не ссылочный тип или является результатом некоторых встроенных операторов. В C++ выражение не является сущностью, поэтому оно не имеет идентичности.

У prvalue всегда есть объект результата, который может быть временным объектом. Объект результата является сущностью, он материализуется при необходимости (когда пытаются получить ссылку на него).


Тип выражения, четко определенный в [expr.type]:

Если выражение изначально имеет тип "ссылка на T" ([dcl.ref], [dcl.init.ref]), тип корректируется до T перед любым дальнейшим анализом. Выражение обозначает объект или функцию, обозначенную ссылкой, и выражение является lvalue или xvalue, в зависимости от выражения. [Примечание: до начала жизни ссылки или после ее окончания поведение не определено (см. [Basic.life]). - конец примечания]

Если значение prvalue изначально имеет тип "cv T", где T - это неквалифицированный cv некласс, не относящийся к массиву, тип выражения корректируется до T перед любым дальнейшим анализом.

Выражение не может иметь ссылочный тип.

Прежде всего, если вы действительно хотите изучить формализмы / детали C++, вам следует обратиться к стандартам (или их проектам); вместо вики-страниц (которые могут быть или не быть правильными; хотя cppreference, как правило, довольно хорошо). См. Где я могу найти текущие стандартные документы C или C++?,

Сказав это, нет необходимости изучать стандарт (ы) C++ для использования языка. На самом деле, большинство разработчиков этого не делают, и наверняка они не предназначены для изучения C++. Это официальный документ, а не учебный / учебный материал. Так что, если вы только изучаете C++, купите хорошую книгу об этом. Вместо этого смотрите Руководство и список книг по C++.


Что значит выражение имеет тип? Это тип конечного результата после оценки?

Нет, его не нужно оценивать (т. Е. Во время выполнения), чтобы иметь тип. Например, sizeof expr имеет тип std::size_t, еще expr не оценивается.

Я не хочу изучать шаблон на данном этапе, будет ли это мешать изучению основной части (с точки зрения вашего эксперта)? Мне потребовалось некоторое время, чтобы понять, что ссылка для пересылки и ссылка на rvalue - это разные вещи, которые для шаблона являются первыми.

На самом деле, все наоборот: если вы хотите изучать C++ для практического использования, вам определенно необходимо изучить хотя бы основы шаблонов (хотя бы для того, чтобы использовать стандартную библиотеку и не потеряться полностью).

Однако формально вам не нужно знать все о том, как они работают с типами значений, ссылками на rvalue или самими шаблонами, чтобы иметь возможность программировать.

фраза беспокоит меня много, это личность

В стандарте нет определения "идентичность". В C++17 он используется в нескольких местах, например, при определении glvalue:

- glvalue - это выражение, оценка которого определяет идентичность объекта, битового поля или функции.

Но, действительно, вы могли бы сказать, что "иметь идентичность" означает "фактически существующее где-то в памяти (если требуется)". Лучшее, что вы можете сделать, чтобы понять эту терминологию, это прочитать то, что написал Страуструп:

"Имеет идентичность" - то есть и адрес, указатель, пользователь может определить, идентичны ли две копии и т. Д.

Вы также можете думать об этом противоположным образом: glvalue (то, что имеет идентичность) - это любое выражение, которое не является prvalue, если это помогает.

Другие вопросы по тегам