КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Запись правил грамматик в графическом виде
При записи правил в графическом виде вся грамматика представляется в форме набора специальным образом построенных диаграмм. Эта форма впервые была предложена при описании грамматики языка Pascal. Она доступна не для всех типов грамматик, а только для контекстно – свободных и регулярных типов, но этого достаточно, чтобы ее можно было использовать для описания грамматик известных языков программирования. В такой форме записи каждому нетерминальному символу грамматики соответствует диаграмма, построенная в виде направленного графа. Граф имеет следующие типы вершин: · точка входа (на диаграмме никак не обозначена, из нее просто начинается входная дуга графа); · нетерминальный символ (на диаграмме обозначается прямоугольник, в который вписано обозначение символа); · цепочка терминальных символов (на диаграмме обозначается овалом, кругом или прямоугольником с закругленными краями, внутрь которого вписана цепочка); · узловая точка (на диаграмме обозначается жирной точкой или закрашенным кружком); · точка выхода (никак не обозначена, в нее просто входит выходная дуга графа). Каждая диаграмма имеет только одну точку входа или выхода, но сколько угодно вершин других трех типов. Вершины соединяются между собой направленными дугами графа (линиями со стрелками). Из входной точки дуги могут только выходить, а во входную точку – только входить. В остальные вершины дуги могут, как входить, так и выходить (в правильно построенной грамматике каждая вершина должна иметь как минимум один вход и как минимум один выход). Чтобы построить цепочку символов, соответствующую какому-либо нетерминальному символу грамматике, надо рассмотреть диаграмму для этого символа. Тогда, начав движение от точки входа, надо двигаться по дугам графа диаграммы через любые вершины до точки выхода. При этом, проходя через вершину, обозначенную нетерминальным символом, этот символ следует поместить в результирующую цепочку. При прохождении через узловые точки диаграммы над результирующей цепочкой никаких действий выполнять не надо. Чрез любую вершину графа диаграммы, в зависимости от возможного пути движения, можно пройти один раз, ни разу или сколько угодно много раз. Как только мы попадем в точку выхода диаграммы, построение результирующей цепочки закончено. Результирующая цепочка, может содержать нетерминальные символы. Чтобы заменить их на цепочки терминальных символов, нужно рассмотреть соответствующие им диаграммы. И так до тех пор, пока в цепочке не останутся только терминальные символы. Очевидно, что для того, чтобы построить цепочку символов заданного языка, надо начать рассмотрение с диаграммы стартового символа грамматики. Описание понятия “число” из грамматики G с помощью диаграмм на рис. 18. Число:
Цифра:
Рис.18. Графическое представление грамматики целых десятичных чисел со знаком: вверху – для понятия “число”; внизу – для понятия ”цифра”
Данный способ в основном применяется в литературе при изложении грамматик языков программирования. Для пользователей – разработчиков программ – он удобен, но практического применения в компиляторах пока не имеет.
Дата добавления: 2014-12-27; Просмотров: 996; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |