Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему 2. Лексика, синтаксис и пр

Содержание

Языки программированияЛексикаОрфографияМорфологияСинтаксисГрамматикаПунктуацияСемантикаПрагматикаСтиль
Языки программированияЯзык – знаковая системаЗнакСмысл (денотат)Цифры «45»Число 45Семантическая функция Val(«45») = 4 * 10 + 5 Языки программированияЛексикаОрфографияМорфологияСинтаксисГрамматикаПунктуацияСемантикаПрагматикаСтиль ЛексикаЛексема – элементарная (относительно синтаксиса) единица языкаПримеры:Числа: 123.4e2, 12, 0x25Знаки: +, !=, [, Лексика - примерИдентификатор – последовательность букв и цифр, начинающаяся с буквыВопросы:Кириллица? Инд2Регистр? Лексика – формальное описаниеРегулярные выражения 			(_|a|…|z)(_|a|…|z|0|…|9)*Конечные автоматы_ a … z_ a … z 0 …9иначеиначе Форма Бэкуса-Наура - БНФНетерминал – определяемое понятиеТерминал – неопределяемый символМетасимволы – ( Пример БНФбуква ::= _буква ::= a...буква ::= zцифра ::= 0…цифра ::= 9букра Регуляризованная БНФ - РБНФАльтернативаразное ::= вариант1...разное ::= вариантnЭквивалентно разное ::= вариант1 | Регуляризованная БНФ - РБНФНеобязательный элемент – возможное отсутствиеможетбыть ::=можетбыть ::= нечтоЭквивалентно Регуляризованная БНФ - РБНФИтерация – повторение ноль или более раз (звезда Клини)много Регуляризованная БНФ - РБНФНенулевая итерация – повторение один или более раз (плюс Пример РБНФбуква ::= _буква ::= a...буква ::= zцифра ::= 0…цифра ::= 9букра Пример РБНФбуква ::= _|a|…|zцифра ::= 0|…|9букра ::= буква		 | цифра букры ::= (букра)*идент ::= буква букры Пример РБНФидент ::= буква (буква | цифра)*буква ::= _|a|…|zцифра ::= 0|…|9 ЛексикаРазделителиПробелы, переводы строк, табуляцииЗначащие позиции: с 7 по 72Комментарии: /*…*/  // Лексика – национальные версии (Алгол 60)проц НОД(x,y,z); знач x,y; цел x,y,z; начало Лексика – национальные версии (проблемы)Для «правильного» перевода нужно менять не только лексику, ЛексикаРезультат – поток лексем Тип лексемы: идентификатор, строка, число...Значение лексемы: изображение, значение числа,.... СинтаксисПравила построения фраз из лексемКонтекстно-свободный - структура фразы не зависит от окруженияКонтекстно-зависимый	Пример Контекстно-свободный синтаксисПример (РБНФ)выр ::= перем 		| конст 		| (+ | -) выр Синтаксический вывод - дерево разбораВыражение: x + 2 * yЗадача: найтипоследовательностьправил выводадля Синтаксический вывод (неоднозначность)Выражение: x + 2 * yвыр * вырперемвырперемвыр + вырxконст2y( Синтаксический вывод (избыточность)Допускается «лишнее»Пример:A < B + C < D+ - + 2X + - Y Контекстно-свободный синтаксисПример – улучшенный вариантвыр ::= прост-выр [(= | < | Синтаксический вывод - дерево разбораВыражение: x + 2 * yслаг + слагвырмнож Неоднозначность ifif (x > 0) 	if (x < 2) 		x = x+1; Неоднозначность ifif (x > 0) 	if (x < 2) 		x = x+1;	fi Синтаксические диаграммыСтруктурированный ориентированный граф с одним входом и одним выходом, вершинами которого Синтаксические диаграммыВход:Выход: Обязательный:НеобязательныйИгнорируемый: Синтаксические диаграммыВыбор:Необязательный выбор: Выбор с умолчанием : Синтаксические диаграммыПовторение:Повторение через разделитель: Синтаксические диаграммыидент ::= A..Z [(A..Z | 0..9)*] Синтаксические диаграммы - пример«Плохая» грамматика Синтаксические диаграммы - примерУлучшенная грамматикавыр ::= прост-выр [(= | < | Синтаксические диаграммы - примерпрост-выр ::= [+ | -] слаг ((+ | -) Синтаксические диаграммы - примермнож ::= перем | конст | ( выр ) Синтаксические диаграммы – понятность пользователюКритериичтобы не было слишком большим (умещалось на странице)чтобы Устойчивость синтаксисаСлучайные ошибки и опечатки должны обнаруживатьсяРазные конструкции должны визуально различатьсяПримеры:for (i = 0; i Контекстно-зависимый анализ	Идентификация – сопоставление определений объектов с их использованиямиСтатический анализ типов – СемантикаЧто делает данная программа?Функциональная семантика – функция, реализуемая программойОперационная семантика –последовательность (содержательных) СтильЛесенка - иногда обязательна (Occam), иногда поддерживается автоматически.	int l1 = busy_class(cl, d*lessons_per_day СтильЛесенка		int l1 = busy_class(cl, d*lessons_per_day + t1);				if (t1 == t 		|| l1 СтильЛесенка else if 		плохо	if (x >=1000)		….	else 	  if (x > 0)		… СтильЛесенка else if	if (x >=1000)		….	else if (x > 0)		…	else if (x == СтильСодержательные, мнемоничные идентификаторыint n1, n2;for (int index_of_outer_loop = 0; СтильСодержательные идентификаторыint PersonCount, ExamCount;for (int p = 0; p < PersonCount; p++)	for СтильНеиспользование умолчанийint cnt = 0;unsigned char line[128]FILE * file;… while ( fgets(line, КомментарииСовсем без комментариев – плохоint max = 0;for (int i = 0; КомментарииС плохими комментариями – ещё хуже/* начальник приказал написать комментарии к каждой КомментарииКомментарии облегчают понимание/* * Нахождение максимума max в массиве M */int max ПрагматикаИспользование конструкций языка согласно их предназначениюwhile (n ПреемственностьFortran -> Fortran IV -> Fortran 77 -> Fortran 90K&R C ->
Слайды презентации

Слайд 2 Языки программирования
Лексика
Орфография
Морфология
Синтаксис
Грамматика
Пунктуация

Семантика
Прагматика
Стиль

Языки программированияЛексикаОрфографияМорфологияСинтаксисГрамматикаПунктуацияСемантикаПрагматикаСтиль

Слайд 3 Лексика
Лексема – элементарная (относительно синтаксиса) единица языка
Примеры:
Числа: 123.4e2,

ЛексикаЛексема – элементарная (относительно синтаксиса) единица языкаПримеры:Числа: 123.4e2, 12, 0x25Знаки: +, !=, [,

12, 0x25
Знаки: +, !=, [,

PersonID
Ключевые слова: while, if
Строки: “Hello, World”, “while + 1”
Символы: ‘a’


Слайд 4 Лексика - пример
Идентификатор – последовательность букв и цифр,

Лексика - примерИдентификатор – последовательность букв и цифр, начинающаяся с буквыВопросы:Кириллица?

начинающаяся с буквы
Вопросы:
Кириллица? Инд2
Регистр? PersonID = PeRSoniD
_? student_count, __FILE__, _1
Длина?

TheBestApproximationReachedSoFar
Другие символы? IsLegal?
Пробелы? Min X

Слайд 5 Лексика – формальное описание
Регулярные выражения
(_|a|…|z)(_|a|…|z|0|…|9)*
Конечные автоматы



_ a

Лексика – формальное описаниеРегулярные выражения 			(_|a|…|z)(_|a|…|z|0|…|9)*Конечные автоматы_ a … z_ a … z 0 …9иначеиначе

… z


_ a … z 0 …9
иначе
иначе


Слайд 6 Форма Бэкуса-Наура - БНФ
Нетерминал – определяемое понятие
Терминал –

Форма Бэкуса-Наура - БНФНетерминал – определяемое понятиеТерминал – неопределяемый символМетасимволы –

неопределяемый символ
Метасимволы – ( ) ::= [ ] *

Правило

грамматики
Нетерминал ::= последовательность терминалов и нетерминалов


Слайд 7 Пример БНФ
буква ::= _
буква ::= a
...
буква ::= z
цифра

Пример БНФбуква ::= _буква ::= a...буква ::= zцифра ::= 0…цифра ::=

::= 0

цифра ::= 9

букра ::= буква
букра ::= цифра

букры

::=
букры ::= букра букры

идент ::= буква букры


Слайд 8 Регуляризованная БНФ - РБНФ
Альтернатива
разное ::= вариант1
...
разное ::= вариантn
Эквивалентно

Регуляризованная БНФ - РБНФАльтернативаразное ::= вариант1...разное ::= вариантnЭквивалентно разное ::= вариант1


разное ::= вариант1 | ... | вариантn
Пример
буква ::=

_ | a | … | z

Слайд 9 Регуляризованная БНФ - РБНФ
Необязательный элемент – возможное отсутствие
можетбыть

Регуляризованная БНФ - РБНФНеобязательный элемент – возможное отсутствиеможетбыть ::=можетбыть ::= нечтоЭквивалентно

::=
можетбыть ::= нечто
Эквивалентно
можетбыть ::= [ нечто ]
Пример
букры

::= [ букра букры ]

Слайд 10 Регуляризованная БНФ - РБНФ
Итерация – повторение ноль или

Регуляризованная БНФ - РБНФИтерация – повторение ноль или более раз (звезда

более раз (звезда Клини)
много ::=
много ::= нечто много
Эквивалентно
много

::= (нечто)*
Пример
букры ::= (букра)*

Слайд 11 Регуляризованная БНФ - РБНФ
Ненулевая итерация – повторение один

Регуляризованная БНФ - РБНФНенулевая итерация – повторение один или более раз

или более раз (плюс Клини)
много ::= нечто
много ::= нечто

много
Эквивалентно
много ::= (нечто)+
Пример
букра (букра)* экививалентно (букра)+
(букра)* экививалентно [(букра)+]


Слайд 12 Пример РБНФ
буква ::= _
буква ::= a
...
буква ::= z
цифра

Пример РБНФбуква ::= _буква ::= a...буква ::= zцифра ::= 0…цифра ::=

::= 0

цифра ::= 9

букра ::= буква
букра ::= цифра

букры

::=
букры ::= букра букры

идент ::= буква букры


Слайд 13 Пример РБНФ
буква ::= _|a|…|z



цифра ::= 0|…|9

букра ::= буква

Пример РБНФбуква ::= _|a|…|zцифра ::= 0|…|9букра ::= буква		 | цифра букры ::= (букра)*идент ::= буква букры

| цифра

букры ::= (букра)*


идент ::= буква букры


Слайд 14 Пример РБНФ





идент ::= буква (буква | цифра)*

буква ::=

Пример РБНФидент ::= буква (буква | цифра)*буква ::= _|a|…|zцифра ::= 0|…|9

_|a|…|z



цифра ::= 0|…|9


Слайд 15 Лексика
Разделители
Пробелы, переводы строк, табуляции
Значащие позиции: с 7 по

ЛексикаРазделителиПробелы, переводы строк, табуляцииЗначащие позиции: с 7 по 72Комментарии: /*…*/ //

72
Комментарии: /*…*/ // до конца строки
Вложенные комментарии
Максимальность лексемы:

a+++++b, <<
Нормализация
1.23 = 0.123e+1
ZERO = ZEROS = ZEROES = 0
Count = COUNT = count

Слайд 16 Лексика – национальные версии (Алгол 60)
проц НОД(x,y,z); знач x,y;

Лексика – национальные версии (Алгол 60)проц НОД(x,y,z); знач x,y; цел x,y,z;

цел x,y,z; начало цел проц ОСТ(A,B); знач A,B; цел A,B;

ОСТ := A – (A % B) * B; начало цел u; для u := ОСТ(x,y) пока u ≠ 0 цикл
начало y := x; x := u конец;
конец;
z := x
конец

Слайд 17 Лексика – национальные версии (проблемы)
Для «правильного» перевода нужно менять

Лексика – национальные версии (проблемы)Для «правильного» перевода нужно менять не только

не только лексику, но и синтаксис, структуру фраз
Русские имена

могут не допускаться окружающей обстановкой
Использование «иноязычных» библиотек
Изображение данных:
числа: десятичная точка или десятичная запятая
даты: 09/01/04 или 04/01/09
Неудобство набора текста
опасность совпадения разных букв по начертанию

Слайд 18 Лексика
Результат – поток лексем
Тип лексемы: идентификатор, строка,

ЛексикаРезультат – поток лексем Тип лексемы: идентификатор, строка, число...Значение лексемы: изображение, значение числа,....

число...
Значение лексемы: изображение, значение числа,....


Слайд 19 Синтаксис
Правила построения фраз из лексем
Контекстно-свободный - структура фразы

СинтаксисПравила построения фраз из лексемКонтекстно-свободный - структура фразы не зависит от

не зависит от окружения
Контекстно-зависимый
Пример (Algol-68): .A x :=

2
Описание переменной с инициализацией, если А – тип
Присваивание 2 по адресу (.A x), если .A - операция

Слайд 20 Контекстно-свободный синтаксис
Пример (РБНФ)
выр ::= перем
| конст
|

Контекстно-свободный синтаксисПример (РБНФ)выр ::= перем 		| конст 		| (+ | -)

(+ | -) выр
| выр (= |

| <= | <> | + | - | * | /) выр
| ( выр )

Слайд 21 Синтаксический вывод - дерево разбора
Выражение: x + 2

Синтаксический вывод - дерево разбораВыражение: x + 2 * yЗадача: найтипоследовательностьправил

* y
Задача: найти
последовательность
правил вывода
для заданной
цепочки
терминалов
выр + выр
перем
выр
перем
выр *

выр

2

конст

y

x

((x) + ((2) * (y) ) )


Слайд 22 Синтаксический вывод (неоднозначность)
Выражение: x + 2 * y
выр *

Синтаксический вывод (неоднозначность)Выражение: x + 2 * yвыр * вырперемвырперемвыр +

выр
перем
выр
перем
выр + выр
x
конст
2
y
( ( x + 2 ) *

y )

Слайд 23 Синтаксический вывод (избыточность)
Допускается «лишнее»
Пример:
A < B + C

Синтаксический вывод (избыточность)Допускается «лишнее»Пример:A < B + C < D+ - + 2X + - Y

D
+ - + 2
X + - Y


Слайд 24 Контекстно-свободный синтаксис
Пример – улучшенный вариант
выр ::= прост-выр [(=

Контекстно-свободный синтаксисПример – улучшенный вариантвыр ::= прост-выр [(= | < |

| < |

| -] слаг ((+ | -) слаг)*
слаг ::= множ ((* | / ) множ)*
множ ::= (перем | конст | ( выр ))

Слайд 25 Синтаксический вывод - дерево разбора
Выражение: x + 2

Синтаксический вывод - дерево разбораВыражение: x + 2 * yслаг +

* y
слаг + слаг
выр
множ * множ
перем
2
конст
y
x
(x + ( 2

* y ) )

прост-выр

множ

перем


Слайд 26 Неоднозначность if
if (x > 0)
if (x

Неоднозначность ifif (x > 0) 	if (x < 2) 		x =

2)
x = x+1;
else
x = x-1;





if (x

> 0)
if (x < 2)
x = x+1;
else
x = x-1;








Слайд 27 Неоднозначность if
if (x > 0)
if (x

Неоднозначность ifif (x > 0) 	if (x < 2) 		x =

2)
x = x+1;
fi
else
x = x-1;
fi




Решение проблемы:


Слайд 28 Синтаксические диаграммы
Структурированный ориентированный граф с одним входом и

Синтаксические диаграммыСтруктурированный ориентированный граф с одним входом и одним выходом, вершинами

одним выходом, вершинами которого являются нетерминалы и терминалы

Допускает цепочку

терминалов на пути от входа к выходу с «заходом» в диаграммы нетерминалов.

Слайд 29 Синтаксические диаграммы
Вход:
Выход:

Обязательный:

Необязательный

Игнорируемый:

Синтаксические диаграммыВход:Выход: Обязательный:НеобязательныйИгнорируемый:

Слайд 30 Синтаксические диаграммы
Выбор:



Необязательный выбор:
Выбор с умолчанием :

Синтаксические диаграммыВыбор:Необязательный выбор: Выбор с умолчанием :

Слайд 31 Синтаксические диаграммы
Повторение:



Повторение через разделитель:

Синтаксические диаграммыПовторение:Повторение через разделитель:

Слайд 32 Синтаксические диаграммы
идент ::= A..Z [(A..Z | 0..9)*]





Синтаксические диаграммыидент ::= A..Z [(A..Z | 0..9)*]

Слайд 33 Синтаксические диаграммы - пример
«Плохая» грамматика

Синтаксические диаграммы - пример«Плохая» грамматика

Слайд 34 Синтаксические диаграммы - пример
Улучшенная грамматика

выр ::= прост-выр [(=

Синтаксические диаграммы - примерУлучшенная грамматикавыр ::= прост-выр [(= | < |

| < |


Слайд 35 Синтаксические диаграммы - пример
прост-выр ::= [+ | -]

Синтаксические диаграммы - примерпрост-выр ::= [+ | -] слаг ((+ |

слаг ((+ | -) слаг)*



слаг ::= множ ((* |

/) множ)*


Слайд 36 Синтаксические диаграммы - пример
множ ::= перем | конст

Синтаксические диаграммы - примермнож ::= перем | конст | ( выр )

| ( выр )


Слайд 37 Синтаксические диаграммы – понятность пользователю
Критерии
чтобы не было слишком

Синтаксические диаграммы – понятность пользователюКритериичтобы не было слишком большим (умещалось на

большим (умещалось на странице)
чтобы не было слишком много диаграмм


Слайд 38 Устойчивость синтаксиса
Случайные ошибки и опечатки должны обнаруживаться
Разные конструкции

Устойчивость синтаксисаСлучайные ошибки и опечатки должны обнаруживатьсяРазные конструкции должны визуально различатьсяПримеры:for (i = 0; i

должны визуально различаться
Примеры:
for (i = 0; i

A[i] = A[i-1];

for (float x=0.0; x<=1,2; f=+0.1)
s = + f(x);

y = a[0]/2 + a[1]//3 + a[2]/5 + a[3]/7
+ a[4]/11 + a[5]/13 + a[6]/17 + a[7]/19;

10 DO I = 1.1,N
S = S * I
CONTINUE

.for i from 10 .to N .do print(“ “) .od;

Algol-68:

Fortran:

С:








Слайд 39 Контекстно-зависимый анализ
Идентификация – сопоставление определений объектов с их

Контекстно-зависимый анализ	Идентификация – сопоставление определений объектов с их использованиямиСтатический анализ типов

использованиями
Статический анализ типов – определение (вывод) типов объектов и

выражений и проверка типовой правильности.


Слайд 40 Семантика
Что делает данная программа?
Функциональная семантика – функция, реализуемая

СемантикаЧто делает данная программа?Функциональная семантика – функция, реализуемая программойОперационная семантика –последовательность

программой
Операционная семантика –последовательность (содержательных) действий выполняемая программой
Аксиоматическая семантика –

следствие постусловий из предусловий

Слайд 41 Стиль
Лесенка - иногда обязательна (Occam), иногда поддерживается автоматически.

int

СтильЛесенка - иногда обязательна (Occam), иногда поддерживается автоматически.	int l1 = busy_class(cl,

l1 = busy_class(cl, d*lessons_per_day + t1); if (t1==t ||

l1==-1 || lessons[l1]-> share[0].teacher != tch) continue; if (t1 < t-1 || t1>t+1) ++ not_sequence; else {++ total_class_overload; sum += B_CLASS_OVERLOAD; }

Неправильно

Слайд 42 Стиль
Лесенка
int l1 = busy_class(cl, d*lessons_per_day + t1);

if (t1

СтильЛесенка		int l1 = busy_class(cl, d*lessons_per_day + t1);				if (t1 == t 		||

== t
|| l1 == -1
|| lessons[l1]->share[0].teacher !=

tch)
continue;

/* Не скупитесь на пробелы */

if (t1 < t-1 || t1 > t+1)
++ not_sequence;
else
{
++ total_class_overload;
sum += B_CLASS_OVERLOAD;
}


Слайд 43 Стиль
Лесенка else if плохо
if (x >=1000)
….
else

СтильЛесенка else if 		плохо	if (x >=1000)		….	else 	 if (x > 0)		…

if (x > 0)

else

if (x == 0)

else
if (x > -1000)

else // x <= -1000


Слайд 44 Стиль
Лесенка else if
if (x >=1000)
….
else if (x >

СтильЛесенка else if	if (x >=1000)		….	else if (x > 0)		…	else if (x

0)

else if (x == 0)

else if (x > -1000)

else

// x <= -1000



Слайд 45 Стиль
Содержательные, мнемоничные идентификаторы
int n1, n2;
for (int index_of_outer_loop =

СтильСодержательные, мнемоничные идентификаторыint n1, n2;for (int index_of_outer_loop = 0;  		index_of_outer_loop

0; index_of_outer_loop < n1;
index_of_outer_loop ++)
for

(int intIndexJ = 0; intIndexJ < n2; intIndexJ ++)


Неправильно

Слайд 46 Стиль
Содержательные идентификаторы
int PersonCount, ExamCount;
for (int p = 0;

СтильСодержательные идентификаторыint PersonCount, ExamCount;for (int p = 0; p < PersonCount;

p < PersonCount; p++)
for (int j = 0; j

< ExamCount; j ++)


Длина идентификатора пропорциональна размеру области его действия

Слайд 47 Стиль
Неиспользование умолчаний

int cnt = 0;
unsigned char line[128]
FILE *

СтильНеиспользование умолчанийint cnt = 0;unsigned char line[128]FILE * file;… while (

file;

while ( fgets(line, 127, file) != NULL)
cnt ++;


Слайд 48 Комментарии
Совсем без комментариев – плохо

int max = 0;
for

КомментарииСовсем без комментариев – плохоint max = 0;for (int i =

(int i = 0; i < n; i++)
if (M[i]

> max)
max = M[i];

Слайд 49 Комментарии
С плохими комментариями – ещё хуже
/* начальник приказал

КомментарииС плохими комментариями – ещё хуже/* начальник приказал написать комментарии к

написать комментарии к каждой строчке – ему же хуже будет

:-[ */
int max = 0; // присвоить 0
// перебираем i=0..n-1
for (int i = 0; i < n; i++)
if (M[i] > max) // сравниваем с max
max = M[i]; // обновляем, если надо

Слайд 50 Комментарии
Комментарии облегчают понимание
/*
* Нахождение максимума max в

КомментарииКомментарии облегчают понимание/* * Нахождение максимума max в массиве M */int

массиве M
*/
int max = 0; // предполагается, что

все M[i] > 0
for (int i = 0; i < n; i++)
if (M[i] > max)
max = M[i];

Слайд 51 Прагматика
Использование конструкций языка согласно их предназначению
while (n

ПрагматикаИспользование конструкций языка согласно их предназначениюwhile (n

n = -n;
break;
}
if (n

-n;

n = (n<0 ? –n : n);


  • Имя файла: 2-leksika-sintaksis-i-pr.pptx
  • Количество просмотров: 113
  • Количество скачиваний: 0