当前位置: 首页 > news >正文

dede制作的网站挂马可以做外贸的网站有哪些

dede制作的网站挂马,可以做外贸的网站有哪些,网站管理文档怎么写,专业做化妆品外包材的招聘网站解释器模式 1#xff09;概述 1.定义 定义一个语言的文法#xff0c;并且建立一个解释器来解释该语言中的句子#xff0c;这里的“语言”是指使用规定格式和语法的代码。 2.结构图 3.角色 AbstractExpression#xff08;抽象表达式#xff09;#xff1a;在抽象表达…解释器模式 1概述 1.定义 定义一个语言的文法并且建立一个解释器来解释该语言中的句子这里的“语言”是指使用规定格式和语法的代码。 2.结构图 3.角色 AbstractExpression抽象表达式在抽象表达式中声明了抽象的解释操作它是所有终结符表达式和非终结符表达式的公共父类。 TerminalExpression终结符表达式它实现了与文法中的终结符相关联的解释操作在句子中的每一个终结符都是该类的一个实例通常在一个解释器模式中只有少数几个终结符表达式类它们的实例可以通过非终结符表达式组成较为复杂的句子。 NonterminalExpression非终结符表达式它实现了文法中非终结符的解释操作由于在非终结符表达式中可以包含终结符表达式也可以继续包含非终结符表达式因此其解释操作一般通过递归的方式来完成。 Context环境类环境类又称为上下文类它用于存储解释器之外的一些全局信息通常它临时存储了需要解释的语句。 注意 在解释器模式中每一种终结符和非终结符都有一个具体类与之对应正因为使用类来表示每一条文法规则所以系统将具有较好的灵活性和可扩展性。 4.代码实现 抽象表达式类 abstract class AbstractExpression {public abstract void interpret(Context ctx); }终结符表达式 public class TerminalExpression extends AbstractExpression {public void interpret(Context ctx) {//终结符表达式的解释操作} }非终结符表达式 public class NonterminalExpression extends AbstractExpression {private AbstractExpression left;private AbstractExpression right;public NonterminalExpression(AbstractExpression left,AbstractExpression right) {this.leftleft;this.rightright;}public void interpret(Context ctx) {//递归调用每一个组成部分的interpret()方法//在递归调用时指定组成部分的连接方式即非终结符的功能} }环境类 public class Context {private HashMap map new HashMap();public void assign(String key, String value) {//往环境类中设值}public String lookup(String key) {//获取存储在环境类中的值} }2完整解决方案 1.解释过程-抽象语法树 2.结构图 AbstractNode充当抽象表达式角色DirectionNode、ActionNode和DistanceNode充当终结符表达式角色AndNode和SentenceNode充当非终结符表达式角色。 3.代码实现 抽象表达式 //抽象表达式 abstract class AbstractNode {public abstract String interpret(); }非终结符表达式 //And解释非终结符表达式 public class AndNode extends AbstractNode {private AbstractNode left; //And的左表达式private AbstractNode right; //And的右表达式public AndNode(AbstractNode left, AbstractNode right) {this.left left;this.right right;}//And表达式解释操作public String interpret() {return left.interpret() 再 right.interpret();} }//简单句子解释非终结符表达式 public class SentenceNode extends AbstractNode {private AbstractNode direction;private AbstractNode action;private AbstractNode distance;public SentenceNode(AbstractNode direction, AbstractNode action, AbstractNode distance) {this.direction direction;this.action action;this.distance distance;}//简单句子的解释操作public String interpret() {return direction.interpret() action.interpret() distance.interpret();} }终结符表达式 //方向解释终结符表达式 public class DirectionNode extends AbstractNode {private String direction;public DirectionNode(String direction) {this.direction direction;}//方向表达式的解释操作public String interpret() {if (direction.equalsIgnoreCase(up)) {return 向上;} else if (direction.equalsIgnoreCase(down)) {return 向下;} else if (direction.equalsIgnoreCase(left)) {return 向左;} else if (direction.equalsIgnoreCase(right)) {return 向右;} else {return 无效指令;}} }//动作解释终结符表达式 public class ActionNode extends AbstractNode {private String action;public ActionNode(String action) {this.action action;}//动作移动方式表达式的解释操作public String interpret() {if (action.equalsIgnoreCase(move)) {return 移动;} else if (action.equalsIgnoreCase(run)) {return 快速移动;} else {return 无效指令;}} }//距离解释终结符表达式 public class DistanceNode extends AbstractNode {private String distance;public DistanceNode(String distance) {this.distance distance;}//距离表达式的解释操作public String interpret() {return this.distance;} }工具类InstructionHandler用于对输入指令进行处理将输入指令分割为字符串数组将第1个、第2个和第3个单词组合成一个句子并存入栈中如果发现有单词“and”则将“and”后的第1个、第2个和第3个单词组合成一个新的句子作为“and”的右表达式并从栈中取出原先所存句子作为左表达式然后组合成一个And节点存入栈中依此类推直到整个指令解析结束。 import java.util.Stack;//指令处理类工具类 public class InstructionHandler {private AbstractNode node;public void handle(String instruction) {AbstractNode left null, right null;AbstractNode direction null, action null, distance null;//声明一个栈对象用于存储抽象语法树Stack stack new Stack();//以空格分隔指令字符串String[] words instruction.split( );for (int i 0; i words.length; i) {if (words[i].equalsIgnoreCase(and)) {//弹出栈顶表达式作为左表达式left (AbstractNode) stack.pop();String word1 words[i];direction new DirectionNode(word1);String word2 words[i];action new ActionNode(word2);String word3 words[i];distance new DistanceNode(word3);right new SentenceNode(direction, action, distance); //右表达式stack.push(new AndNode(left, right)); //将新表达式压入栈中} else {//如果是从头开始进行解释则将前三个单词组成一个简单句子SentenceNode并将该句子压入栈中String word1 words[i];direction new DirectionNode(word1);String word2 words[i];action new ActionNode(word2);String word3 words[i];distance new DistanceNode(word3);left new SentenceNode(direction, action, distance);//将新表达式压入栈中stack.push(left);}}this.node (AbstractNode) stack.pop(); //将全部表达式从栈中弹出}public String output() {return node.interpret();} }客户端类 public class Client {public static void main(String[] args) {String instruction up move 5 and down run 10 and left move 5;InstructionHandler handler new InstructionHandler();handler.handle(instruction);String outString;outString handler.output();System.out.println(outString);} }
http://www.zqtcl.cn/news/842731/

相关文章:

  • 网站建设禁止谷歌收录的办法做挂网站
  • 佛山优化网站公司做购物网站需要多少钱
  • 山东网站建设维护营销型网站是什么样的
  • 长沙营销网站建设苏州风险区域最新
  • 个人网站百度推广收费wordpress发邮件慢
  • 三门峡网站设计wordpress 去掉功能
  • 网站小程序开发公司wordpress 用户授权
  • 做外贸的几个网站响应式网站wordpress摄影
  • 专业建设网站技术wordpress 虚拟资源
  • 广告网站设计哪家快网站建设外包包含内容
  • 网页游戏网站模板张家口住房和城乡建设部网站
  • 冀州建设局网站公司制作网站多少钱
  • 建设个招聘网站黄页88和58那个推广好
  • 如何设计一个漂亮的网站电商设计素材
  • 沈阳建设银行网站首页果冻影视传媒有限公司
  • 建设部网站有建筑施工分包网站规划设计方案
  • 网站wap怎么做郑州做网站华久科技
  • 哪里网站开发好姜堰网站定制
  • 广东网站开发需要多少钱百度问答官网
  • 建设电影网站的关键wordpress简码怎么用
  • 做网站的linux程序代码北京公司减资流程
  • 四川省住房建设厅网站进不去wordpress 无限下拉菜单
  • 培训网站图片网络编程基础知识
  • 外销网站怎么做的上海住房与城乡建设部网站
  • 平台网站建设教程网站建设谈业务要知道什么
  • php网站开发试题济南网站排名公司
  • 没有官方网站怎么做seo优化营销推广平台都干什么的
  • 网盘搜索网站怎么做中国建设银行网站股份结构变化
  • 有ip怎么用自己的主机做网站惠州网站制作维护
  • 优质的网站制作在线编辑器