Конспект установочных лекций по комплексному курсу Информатика, Теория информации


Объявление элемента


Пусть х - любой идентификатор, s - тип, а Е - выражение этого типа; тогда s х: Е называется объявлением элемента или согласованием элемента с идентификатором х. Через объявление элемента идентификатор х связывается со значением выражения Е. С помощью такого объявления принимается соглашение о том, что с этого момента х стоит в качестве этого значения.

Область связанности, порождаемая объявлением ограничивается блоком, в начале которого и помещаются объявления. Пусть G -объявление, а ЕО - выражение. Тогда

[О; EO]

есть блок. Угловые скобки называют скобками блока. Они ограничивают область действия объявления G,

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

Синтаксис объявления элемента описывается следующим БНФ-правилом:

<объявление_элемента>:: =<тип><идентификатор>=<выражение>

Пусть для объявления элемента справедливы следующие дополнительные условия:

·

тип выражения Е есть s;

·         х не входит свободно в Е.

Второе условие указывает на то, что в модельном языке не допускаются рекурсивные объявления элементов.

Пример (объявление элемента). С помощью объявления



nat х = 3 + 4

принимается соглашение о том, что х имеет значение 7. Это объявление может использоваться в каком-либо блоке. Блок

[nat x =3+4;x*x]

имеет тогда значение 49. Внутри блока х стоит в качестве значения 7.

В ЯП вместо угловых скобок часто записываются также begin и end. Тогда блок будет записываться в виде

begin s х = El; E2 end

Скобки блока begin (соответствующая [) и end (соответствующая ]) ограничивают область действия описания для идентификатора х. Внутри этой области могут приниматься другие, вложенные соглашения, и тогда исходное соглашение на время теряет свою силу (становится "невидимым"). Так, значение блока

[nat х= 1; [nat х =2; х ] + х ] идентично блоку


[nаt х = 1; [nat у = 2; у ] + х ].

Систематическое переименование идентификаторов в локальных объявлениях в блоке (аналог
-редукции) не меняет значения блока.

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

[s x=- El; E2]

соглашение о связывании идентификатора х со значением Е1 имеет силу во всей области, находящейся между угловыми скобками, в частности и в E2, причем действие этого соглашения прерывается с помощью соглашений, принимаемых (через соответствующие объявления) в E2. Это проясняет различие между длительностью жизни и областью видимости связывания. Длительность жизни, т.е. область связанности, охватывает всю область между угловыми скобками (т.е., в частности, и полностью E2). А область видимости соответствует длительности жизни за вычетом внутренних блоков с новыми связываниями для х.

С помощью объявления элемента устанавливаются конкретизации для соответствующего идентификатора. Область действия такой конкретизации ограничивается угловыми скобками. Внутри угловых скобок х стоит в качестве значения выражения Е1. Семантически это означает, что E2 интерпретируется с соответствующим изменением конкретизации для х. Значение I[G] объявления G можно понимать как "точечное" (локальное) изменение подстановки и тем самым как отображение между конкретизациями.

Caмo объявление не обладает никаким простым элементом данных в качестве значения, поэтому оно не вычисляется непосредственно с помощью правил подстановки термов. В дальнейшем будет даваться исключительно правило для вычисления значения выражения, в котором встречается объявление.

Все сказанное относительно связывания, видимости, длительности жизни и свободности или связанности идентификаторов для абстракции функций справедливо и для объявлений.


Содержание раздела