Chan Chen Coding...

          Nine: Interpreter Design Pattern

          Interpreter解釋器設計模式的定義:給定一個語言,定義其文法的一種表示,并定義一個解釋器,這個解釋器使用該表示來解釋語言中的句子。

          Interpreter解釋器設計模式角色如下:

          (1).抽象表達式(AbstractExpression)角色:聲明一個所有的具體表達式角色都需要實現的抽象接口。這個接口主要定義一個interpret()方法,稱做解釋操作。 
          (2).終結符表達式(TerminalExpression)角色:沒有子節點的表達式。 
          (3).非終結符表達式(NonterminalExpression)角色:有子節點的表達式,解釋操作以遞歸方式調用其子節點表達式。 

          (4).上下文(Context)角色:上下文提供解釋器之外的一些全局信息,比如變量的真實量值等。 

          Interpreter解釋器設計模式結構如下:


          通過編寫一個模擬java中日期格式化為指定字符串的例子來演示Interpreter解釋器設計模式,代碼如下:

          [java] view plaincopy



          package behavioral.interpreter.pattern;

          import java.util.Date;

          public interface AbstractExpression {

              public String format(Date date);;
          }



          package behavioral.interpreter.pattern;

          import java.util.Calendar;
          import java.util.Date;

          public class DataFormatExpression implements AbstractExpression {

              private static final String        pattern1    = "yyyy-MM-dd";
              private static final String        pattern2    = "yyyy/MM/dd";
              private static final Calendar    calendar    = Calendar.getInstance();

              private String                                separator    = "";

              public DataFormatExpression() {
              };

              public DataFormatExpression(String pattern) {
                  if (pattern1.equals(pattern)) {
                      separator = "-";
                  } else if (pattern.equals(pattern)) {
                      separator = "/";
                  }
              }

              public String getYear(Calendar cal) {
                  return cal.get(Calendar.YEAR) + "";
              }

              public String getMonth(Calendar cal) {
                  int month = cal.get(Calendar.MONTH) + 1;
                  return month < 10 ? "0" + month : "" + month;
              }

              public String getDay(Calendar cal) {
                  int day = cal.get(Calendar.DAY_OF_MONTH);
                  return day < 10 ? "0" + day : "" + day;
              }

              @Override
              public String format(Date date) {
                  calendar.setTime(date);
                  return getYear(calendar) + separator + getMonth(calendar) + separator + getDay(calendar);
              }
          }




          package behavioral.interpreter.pattern;

          import java.util.Date;

          public class InterpreterDemo {

              public static void main(String[] args) {
                  Date date = new Date();
                  AbstractExpression expression1 = new DataFormatExpression();
                  System.out.println(expression1.format(date));

                  AbstractExpression expression2 = new DataFormatExpression("yyyy-MM-dd");
                  System.out.println(expression2.format(date));

                  AbstractExpression expression3 = new DataFormatExpression("yyyy/MM/dd");
                  System.out.println(expression3.format(date));
              }
          }

          Interpreter解釋器設計模式的應用場景:

          在軟件構建過程中,若果某一特定領域的問題比較復雜,類似的模式不斷重復出現,如果使用普通的編程方式來實現將面臨非常頻繁的變化。在這種情況下,將特定領域的問題表達為某種語法規則下的句子,再構建一個解釋器來解釋這樣的句子,從而達到解決問題的目的。

          JDK中Interpreter解釋器設計模式典型應用就是正則表達式。



          -----------------------------------------------------
          Silence, the way to avoid many problems;
          Smile, the way to solve many problems;

          posted on 2012-11-05 10:34 Chan Chen 閱讀(260) 評論(0)  編輯  收藏 所屬分類: Design Pattern

          主站蜘蛛池模板: 轮台县| 秦皇岛市| 阳西县| 广昌县| 正蓝旗| 乐山市| 西乌珠穆沁旗| 锦州市| 永康市| 巴东县| 广宁县| 务川| 西城区| 乌鲁木齐市| 新蔡县| 瑞丽市| 三原县| 罗平县| 沙湾县| 元谋县| 沅陵县| 炉霍县| 商城县| 铁岭县| 沙田区| 汉源县| 洮南市| 独山县| 齐齐哈尔市| 永新县| 廊坊市| 绩溪县| 安塞县| 文水县| 永昌县| 许昌市| 周至县| 涞源县| 连云港市| 望城县| 石屏县|