WikiDer > Ценность (информатика)
Эта статья нужны дополнительные цитаты для проверка. (Август 2009 г.) (Узнайте, как и когда удалить этот шаблон сообщения) |
В Информатика, а ценить представляет собой представление некоторой сущности, которой можно управлять с помощью программы. Члены тип являются значениями этого типа.[1]
«Значение переменной» дается соответствующим отображение в среда.[нужна цитата] На языках с присваиваемые переменные возникает необходимость различать r-значение (или содержание) и l-значение (или расположение) переменной.[2]
В декларативный (высокий уровень) языки, ценности должны быть ссылочно прозрачный. Это означает, что результирующее значение не зависит от места, в котором хранится (под) выражение, необходимое для вычисления значения. Только содержимое местоположения (биты, равны ли они 1 или 0) и их интерпретация имеют значение.[нужна цитата]
Присвоение: l-значения и r-значения
В некоторых языках используется идея l-значения и r-значения, происходящий из типичного режима оценки в левой и правой частях оператора присваивания. L-значение относится к объекту, который сохраняется за пределами одного выражения. Значение r - это временное значение, которое не сохраняется за пределами выражения, которое его использует.[3]
Понятие l-значений и r-значений было введено Комбинированный язык программирования (CPL). Понятия в выражении r-value, l-value и r-value / l-value аналогичны параметр режимы входного параметра (имеет значение), выходной параметр (может быть назначен) и параметр ввода / вывода (имеет значение и может быть назначен), хотя технические детали различаются в зависимости от контекста и языка.
R-значения и адреса
На многих языках, особенно Семья C, l-значения имеют адреса хранения которые программно доступны для запущенной программы (например, через некоторый оператор адресации, такой как "&" в C / C ++), что означает, что они являются переменными или ссылками на определенное место в памяти. R-значения могут быть l-значениями (см. Ниже) или не-l-значениями - термин, используемый только для отличия от l-значений. Рассмотрим выражение C 4 + 9
. При выполнении компьютер генерирует целочисленное значение 13, но поскольку программа не указала явно, где в компьютере хранится это 13, выражение не является l-значением. С другой стороны, если программа на C объявляет переменную x и присваивает x значение 13, тогда выражение Икс
имеет значение 13 и является l-значением.
В языке C термин l-значение первоначально означал то, что может быть присвоено (отсюда и название, указывающее, что оно находится слева от оператора присваивания), но поскольку зарезервированное слово const
(константа) была добавлена в язык, термин теперь «изменяемое l-значение». В C ++ 11 специальный семантический глиф &&
существует (не путать с &&
оператор, используемый для логических операций), чтобы обозначить использование / доступ адреса выражения для компилятор Только; то есть адрес не может быть получен с использованием адреса &
оператор во время время выполнения программы (см. использование семантики перемещения).
Этот тип ссылки может быть применен к все r-значения, включая не-l-значения, а также l-значения. Некоторые процессоры предоставляют одну или несколько инструкций, которые немедленная ценность, иногда сокращенно называют "немедленным". Непосредственное значение сохраняется как часть инструкции, которая использует его, обычно для загрузки, добавления или вычитания из регистра. Остальные части инструкции - это код операции, и пункт назначения. Последнее может быть неявным. (Непосредственное значение может находиться в регистре или храниться в другом месте в памяти, требуя, чтобы инструкция содержала прямой или косвенный адрес [например, адрес индексного регистра] для значения.)
Выражение l-значения обозначает объект (относится к нему). Немодифицируемое l-значение можно адресовать, но нельзя присвоить. Изменяемое l-значение позволяет как изменять, так и исследовать обозначенный объект. Значение r - это любое выражение, значение, отличное от l, - это любое выражение, которое не является значением l. Одним из примеров является "немедленное значение" (см. Ниже) и, следовательно, не адресуемое.
На языке ассемблера
Значением могут быть практически любые данные по заданному тип данных, например, строка, цифра, отдельная буква.
Процессоры часто поддерживают более одного размера немедленных данных, например 8 или 16 бит, с использованием уникального кода операции и мнемоники для каждого варианта инструкции. Если программист предоставляет значение данных, которое не подходит, ассемблер выдает сообщение об ошибке «Out of range». Большинство ассемблеров позволяют выражать непосредственное значение как ASCII, десятичный, шестнадцатеричный, восьмеричный, или же двоичный данные. Таким образом, символ ASCII 'А'
такой же как 65
или же 0x41
. В порядок байтов Количество строк может различаться между процессорами, в зависимости от ассемблера и архитектуры компьютера.
Примечания
- ^ Митчелл 1996, п. 9.
- ^ Митчелл 1996С. 389–390.
- ^ «Lvalues и Rvalues (Visual C ++)». Сеть разработчиков Microsoft. Получено 3 сентября 2016.
Рекомендации
- Митчелл, Джон С. (1996). Основы языков программирования. MIT Press. ISBN 0-262-13321-0.CS1 maint: ref = harv (связь)
- Стрейчи, Кристофер (2000). «Основные понятия языков программирования». Вычисление высшего порядка и символическое вычисление. 13: 11–49. Дои:10.1023 / А: 1010000313106.CS1 maint: ref = harv (связь)