解释器

    解释器模式(Interpreter)是一种针对特定问题设计的一种解决方案。例如,匹配字符串的时候,由于匹配条件非常灵活,使得通过代码来实现非常不灵活。举个例子,针对以下的匹配条件:

    • 以开头的数字表示的区号和电话号码,如+861012345678
    • 以英文开头,后接英文和数字,并以.分隔的域名,如;

    因此,需要一种通用的表示方法——正则表达式来进行匹配。正则表达式就是一个字符串,但要把正则表达式解析为语法树,然后再匹配指定的字符串,就需要一个解释器。

    类似的,当我们使用JDBC时,执行的SQL语句虽然是字符串,但最终需要数据库服务器的SQL解释器来把SQL“翻译”成数据库服务器能执行的代码,这个执行引擎也非常复杂,但对于使用者来说,仅仅需要写出SQL字符串即可。

    请实现一个简单的解释器,它可以以SLF4J的日志格式输出字符串:

    1. log("[{}] start {} at {}...", LocalTime.now().withNano(0), "engine", LocalDate.now());

    解释器模式通过抽象语法树实现对用户输入的解释执行。

    解释器模式的实现通常非常复杂,且一般只能解决一类特定问题。