国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|JavaScript|易語言|

服務器之家 - 編程語言 - JAVA教程 - 23種設計模式(15)java解釋器模式

23種設計模式(15)java解釋器模式

2021-03-03 13:58阿木俠 JAVA教程

這篇文章主要為大家詳細介紹了23種設計模式之java解釋器模式,具有一定的參考價值,感興趣的小伙伴們可以參考一下

23種設計模式第十五篇:java解釋器模式

定義:給定一種語言,定義他的文法的一種表示,并定義一個解釋器,該解釋器使用該表示來解釋語言中句子。

類型:行為類模式

類圖:

23種設計模式(15)java解釋器模式

        解釋器模式是一個比較少用的模式,本人之前也沒有用過這個模式。下面我們就來一起看一下解釋器模式。

解釋器模式的結構

抽象解釋器:聲明一個所有具體表達式都要實現的抽象接口(或者抽象類),接口中主要是一個interpret()方法,稱為解釋操作。具體解釋任務由它的各個實現類來完成,具體的解釋器分別由終結符解釋器TerminalExpression和非終結符解釋器NonterminalExpression完成。

終結符表達式:實現與文法中的元素相關聯的解釋操作,通常一個解釋器模式中只有一個終結符表達式,但有多個實例,對應不同的終結符。終結符一半是文法中的運算單元,比如有一個簡單的公式R=R1+R2,在里面R1和R2就是終結符,對應的解析R1和R2的解釋器就是終結符表達式。                               

非終結符表達式:文法中的每條規則對應于一個非終結符表達式,非終結符表達式一般是文法中的運算符或者其他關鍵字,比如公式R=R1+R2中,+就是非終結符,解析+的解釋器就是一個非終結符表達式。非終結符表達式根據邏輯的復雜程度而增加,原則上每個文法規則都對應一個非終結符表達式。

環境角色:這個角色的任務一般是用來存放文法中各個終結符所對應的具體值,比如R=R1+R2,我們給R1賦值100,給R2賦值200。這些信息需要存放到環境角色中,很多情況下我們使用Map來充當環境角色就足夠了。

代碼實現

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
class Context {}
 abstract class Expression {
  public abstract Object interpreter(Context ctx);
 }
 class TerminalExpression extends Expression {
  public Object interpreter(Context ctx){
   return null;
  }
 }
 class NonterminalExpression extends Expression {
  public NonterminalExpression(Expression...expressions){
    
  }
  public Object interpreter(Context ctx){
   return null;
  }
 }
 public class Client {
  public static void main(String[] args){
   String expression = "";
   char[] charArray = expression.toCharArray();
   Context ctx = new Context();
   Stack<Expression> stack = new Stack<Expression>();
   for(int i=0;i<charArray.length;i++){
    //進行語法判斷,遞歸調用
   }
   Expression exp = stack.pop();
   exp.interpreter(ctx);
  }
 }

        文法遞歸的代碼部分需要根據具體的情況來實現,因此在代碼中沒有體現。抽象表達式是生成語法集合的關鍵,每個非終結符表達式解釋一個最小的語法單元,然后通過遞歸的方式將這些語法單元組合成完整的文法,這就是解釋器模式。

解釋器模式的優缺點

        解釋器是一個簡單的語法分析工具,它最顯著的優點就是擴展性,修改語法規則只需要修改相應的非終結符就可以了,若擴展語法,只需要增加非終結符類就可以了。
        但是,解釋器模式會引起類的膨脹,每個語法都需要產生一個非終結符表達式,語法規則比較復雜時,就可能產生大量的類文件,為維護帶來非常多的麻煩。同時,由于采用遞歸調用方法,每個非終結符表達式只關心與自己相關的表達式,每個表達式需要知道最終的結果,必須通過遞歸方式,無論是面向對象的語言還是面向過程的語言,遞歸都是一個不推薦的方式。由于使用了大量的循環和遞歸,效率是一個不容忽視的問題。特別是用于解釋一個解析復雜、冗長的語法時,效率是難以忍受的。

解釋器模式的適用場景

在以下情況下可以使用解釋器模式:
有一個簡單的語法規則,比如一個sql語句,如果我們需要根據sql語句進行rm轉換,就可以使用解釋器模式來對語句進行解釋。

一些重復發生的問題,比如加減乘除四則運算,但是公式每次都不同,有時是a+b-c*d,有時是a*b+c-d,等等等等個,公式千變萬化,但是都是由加減乘除四個非終結符來連接的,這時我們就可以使用解釋器模式。

注意事項

       解釋器模式真的是一個比較少用的模式,因為對它的維護實在是太麻煩了,想象一下,一坨一坨的非終結符解釋器,假如不是事先對文法的規則了如指掌,或者是文法特別簡單,則很難讀懂它的邏輯。解釋器模式在實際的系統開發中使用的很少,因為他會引起效率、性能以及維護等問題。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 中文字幕精品一区久久久久 | 国产主播福利 | 中文字幕在线免费 | 精品久久久久久久久久久 | 欧美日韩在线电影 | 狠狠操综合网 | 99在线视频精品 | 伊人成人222 | 亚洲视频在线播放 | 福利一区二区 | 中文字幕精品一区二区精品 | 成人免费激情视频 | 色综合天天综合网国产成人网 | 综合久久亚洲 | 欧美日韩精品在线 | 日韩一区二区三区在线播放 | 六月婷操| 国产欧美在线观看 | 亚洲 综合 清纯 丝袜 自拍 | 久在线视频 | 91精品一区二区三区久久久久久 | 91短视频版在线观看www免费 | 91久久 | 日本免费中文字幕 | www,四虎| 久久黄色 | ts人妖另类精品视频系列 | 免费的成人毛片 | 亚洲三级在线观看 | 日韩在线视频一区 | 91中文在线观看 | 国产精品v一区二区三区 | 国产人成精品一区二区三 | 中文字幕久久精品 | 午夜影视 | 亚洲精品一区二区 | 有码一区| 69久久 | 欧美精品国产精品 | 久久99国产精品 | 欧美第一专区 |