Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Design Patterns by D.pdf
Скачиваний:
25
Добавлен:
19.02.2016
Размер:
2.57 Mб
Скачать

Interpreter — Интерпретатор

Шаблон Интерпретатор (англ. Interpreter) — поведенческий шаблон проектирования, решающий часто встречающуюся, но подверженную изменениям, задачу. Также известен как Little (Small) Language

Проблема

Имеется часто встречающаяся, подверженная изменениям задача.

Решение

Создать интерпретатор, который решает данную задачу.

Преимущества

Грамматику становится легко расширять и изменять, реализации классов, описывающих узлы абстрактного синтаксического дерева похожи (легко кодируются). Можно легко изменять способ вычисления выражений.

Недостатки

Сопровождение грамматики с большим числом правил затруднительно.

Пример

Задача поиска строк по образцу может быть решена посредством создания интерпретатора, определяющего грамматику языка. "Клиент" строит предложение в виде абстрактного синтаксического дерева, в узлах которого находятся объекты классов "НетерминальноеВыражение" и "ТерминальноеВыражение" (рекурсивное), затем "Клиент" инициализирует контекст и вызывает операцию Разобрать(Контекст). На каждом узле типа "НетерминальноеВыражение" определяется операция Разобрать для каждого подвыражения. Для класса "ТерминальноеВыражение" операция Разобрать определяет базу рекурсии. "АбстрактноеВыражение" определяет абстрактную операцию Разобрать, общую для всех узлов в абстрактном синтаксическом дереве. "Контекст" содержит информацию, глобальную по отношению к интерпретатору.

Структура

Пример реализации using System;

using System.Collections;

namespace DoFactory.GangOfFour.Interpreter.Structural

{

/// <summary>

72

///MainApp startup class for Structural

///Interpreter Design Pattern.

///</summary>

class MainApp

{

///<summary>

///Entry point into console application.

///</summary>

static void Main()

{

Context context = new Context();

// Usually a tree

ArrayList list = new ArrayList();

//Populate 'abstract syntax tree' list.Add(new TerminalExpression()); list.Add(new NonterminalExpression()); list.Add(new TerminalExpression()); list.Add(new TerminalExpression());

//Interpret

foreach (AbstractExpression exp in list)

{

exp.Interpret(context);

}

// Wait for user Console.ReadKey();

}

}

///<summary>

///The 'Context' class

///</summary>

class Context

{

}

///<summary>

///The 'AbstractExpression' abstract class

///</summary>

abstract class AbstractExpression

{

public abstract void Interpret(Context context);

}

///<summary>

///The 'TerminalExpression' class

///</summary>

class TerminalExpression : AbstractExpression

{

public override void Interpret(Context context)

{

Console.WriteLine("Called Terminal.Interpret()");

}

}

///<summary>

///The 'NonterminalExpression' class

///</summary>

class NonterminalExpression : AbstractExpression

{

public override void Interpret(Context context)

{

73

Console.WriteLine("Called Nonterminal.Interpret()");

}

}

}

/* Output

Called Terminal.Interpret() Called Nonterminal.Interpret() Called Terminal.Interpret() Called Terminal.Interpret()

*/

74

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]