Erich Gamma Ralph Johnson Richard Helm John Vlissides Addison-Wesley



Download 6,32 Mb.
Pdf ko'rish
bet187/273
Sana02.03.2022
Hajmi6,32 Mb.
#479589
1   ...   183   184   185   186   187   188   189   190   ...   273
Bog'liq
Priemioop

Паттерн Interpreter
Название и классификация паттерна
Интерпретатор - паттерн поведения классов.
Назначение
Для
заданного языка определяет представление его грамматики, а также ин-
терпретатор предложений этого языка.


Паттерн Interpreter
Мотивация
Если некоторая задача возникает часто, то имеет смысл представить ее кон-
кретные проявления в виде предложений на простом языке. Затем можно будет
создать интерпретатор, который решает задачу, анализируя предложения этого
языка.
Например, поиск строк по образцу - весьма распространенная задача. Регуляр-
ные выражения - это стандартный язык для задания образцов поиска. Вместо того
чтобы программировать специализированные алгоритмы для сопоставления строк
с каждым образцом, не проще ли построить алгоритм поиска так, чтобы он мог ин-
терпретировать регулярное выражение, описывающее множество строк-образцов?
Паттерн интерпретатор определяет грамматику простого языка, представля-
ет предложения на этом языке и интерпретирует их. Для приведенного примера
паттерн описывает определение грамматики и интерпретации языка регулярных
выражений.
Предположим, что они описаны следующей грамматикой:
expression ::= literal | alternation | sequence | repetition |
1
( ' expression ' ) '
alternation : : = expression ' | ' expression
sequence : : = expression ' & ' expression
repetition : : = expression ' * '
literal : : = ' a
1
| ' b ' | ' c ' | . . . { ' a
1
| ' b ' | ' c
1
| ... } *
где expression - это начальный символ, a literal - терминальный символ,
определяющий простые слова.
Паттерн интерпретатор использует класс для представления каждого пра-
вила грамматики. Символы в правой части правила - это переменные экземпля-
ров таких классов. Для представления приведенной выше грамматики требуется
пять классов: абстрактный класс RegularExpression и четыре его подкласса
LiteralExpression, AlternationExpression, SequenceExpression
и RepetitionExpression. В последних трех подклассах определены перемен-
ные для хранения подвыражений.



Download 6,32 Mb.

Do'stlaringiz bilan baham:
1   ...   183   184   185   186   187   188   189   190   ...   273




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish