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

网站建设与管理专业好不好就业it培训机构出来能找到工作吗

网站建设与管理专业好不好就业,it培训机构出来能找到工作吗,网页设计与网站建设 作业,沈阳建网站企业23种设计模式之模板方法模式(Template Method Pattern) 基本概念 模板方法模式是一种行为型设计模式,它定义了一个算法骨架,将某些算法步骤的实现延迟到子类中。 这样可以使得算法的框架不被修改,但是具体的实现可以…

23种设计模式之模板方法模式(Template Method Pattern)

基本概念

模板方法模式是一种行为型设计模式,它定义了一个算法骨架,将某些算法步骤的实现延迟到子类中。
这样可以使得算法的框架不被修改,但是具体的实现可以根据需要进行调整。

结构组成

在模板方法模式中,我们通常会定义一个抽象类,它包含了一个模板方法一些抽象方法,这些抽象方法通常由子类来实现

  • 定义抽象类(Abstract Class):抽象类中定义了一些抽象方法和一个模板方法。抽象方法通常是一些具体步骤,而模板方法则定义了算法的大致流程。由于抽象类中的某些方法需要由子类来实现,因此它们往往是 protected 访问权限。
  • 定义具体子类(Concrete Class):具体子类继承自抽象类,并实现其中的抽象方法。在具体子类中,我们可以针对需要实现的具体步骤编写相应的代码。

(1)小栗子

假设我们需要 实现一个炒菜的步骤,炒菜的步骤是固定的,分为倒油、热油、倒蔬菜、倒调料品、翻炒等步骤。现通过模板方法模式来用代码模拟。

抽象类

public abstract class AbstractClass {/*** 定义唯一一个模板方法,定义了基本方法的执行流程,因为执行流程是固定的不应该被修改,所以使用final修饰*/public final void cookProcess() {pourOil();heatOil();pourVegetable();pourSauce();fry();}/*** 第一步,倒油*/public void pourOil() {System.out.println("倒油");}/*** 第二步,热油,直接实现该方法*/public void heatOil() {System.out.println("热油");}/*** 第三步,倒素菜,这是不一样的,一个是下包菜,一个是下空心菜,* 需要用户自己实现,抽象方法*/public abstract void pourVegetable();/*** 第四步,倒调味料,这也是不一样的,抽象方法*/public abstract void pourSauce();/*** 第五步,翻炒*/public void fry() {System.out.println("翻炒至熟");}
}

具体子类1 炒包菜

/*** 炒包菜*/
public class FryDaBaiCai extends AbstractClass{@Overridepublic void pourVegetable() {System.out.println("放入大白菜");}@Overridepublic void pourSauce() {System.out.println("放入辣椒");}
}

具体子类2 炒空心菜

/*** 炒空心菜*/
public class FryKxc extends AbstractClass{@Overridepublic void pourVegetable() {System.out.println("放入空心菜");}@Overridepublic void pourSauce() {System.out.println("放入大蒜");}
}

测试

public class FryTest {public static void main(String[] args) {FryDaBaiCai fryDaBaiCai = new FryDaBaiCai();fryDaBaiCai.cookProcess();FryKxc fryKxc = new FryKxc();fryKxc.cookProcess();}
}

输出结果:

倒油
热油
放入大白菜
放入辣椒
翻炒至熟
--------------------------------
倒油
热油
放入空心菜
放入大蒜
翻炒至熟    

(2)小栗子

假设我们要实现一个对一个数组进行排序的程序,我们可以定义一个抽象类 ArraySorter,其中包含一个模板方法 sort
这个方法包含以下步骤:检查数组是否为空、确定排序算法、调用具体的排序算法。
我们可以将其中一步 “调用具体的排序算法” 延迟到子类中具体实现。在具体子类中,我们可以实现具体的排序算法,如快排、冒泡排序、插入排序等。

抽象类

public abstract class ArraySorter {public final void sort(int[] array) {if (array == null || array.length == 0) {return;}selectAlgorithm();sortArray(array);}protected abstract void selectAlgorithm();protected abstract void sortArray(int[] array);
}

具体子类1-冒泡排序

public class BubbleSorter extends ArraySorter {@Overrideprotected void selectAlgorithm() {System.out.println("Bubble sorting algorithm selected.");}@Overrideprotected void sortArray(int[] array) {// 具体的冒泡排序算法实现}
}

具体子类2-快速排序

public class QuickSorter extends ArraySorter {@Overrideprotected void selectAlgorithm() {System.out.println("Quick sorting algorithm selected.");}@Overrideprotected void sortArray(int[] array) {// 具体的快排算法实现}
}

测试

我们定义了一个抽象类 ArraySorter,其中包含一个模板方法 sort。在具体子类中,我们分别实现了 BubbleSorter 和 QuickSorter,重写了父类的 selectAlgorithm 和 sortArray 方法。
当需要对数组进行排序时,只需要创建一个具体的子类,并调用 sort 方法即可。例如:

public class TestSelectSort {public static void main(String[] args) {int[] array = {1,2,3,4,5,6,7};ArraySorter sorter = new BubbleSorter();sorter.sort(array);}
}
http://www.yidumall.com/news/61666.html

相关文章:

  • 笔记本做网站服务器企业网站seo优化
  • 做微商截图的网站青岛网站运营
  • 网站开发工程师证书网络广告策划书
  • 网站空间和服务器的区别友情链接作用
  • 免费网上商城模板知乎seo
  • jsp做购物网站技术可行性乱码链接怎么用
  • 唐山做网站优化公司日照网络推广公司
  • 手机端网站开发价格成都网站设计公司
  • 权重较高网站软文广告推广
  • 外贸类网站模板凡科网站官网
  • 男女做羞羞羞的网站南宁百度关键词排名公司
  • 南宁网站制作公司云盘网页版登录
  • 国外做节目包装的网站手机百度极速版
  • 自己做网站的劣势html制作网页代码
  • 自己怎样做公司广告视频网站网站运营一个月多少钱
  • 网站建设模板ppt友妙招链接怎么弄
  • 动态网站与建设实训心得电商seo与sem是什么
  • discuz可以做商城网站吗百度关键词排名点击器
  • 网站伪静态是什么意思策划方案
  • 武汉高端网站制作公司cpc广告接单平台
  • wordpress 修改ipseoul是什么意思
  • 搜狗推广登录平台龙泉驿网站seo
  • 龙口做网站哪家好怎么免费建立网站
  • 简单网页尝试做教案广州seo推广优化
  • 搜索引擎推广实训关键词优化快排
  • 企业网站开发实训过程与内容常州seo第一人
  • 设计制作一个网站台湾搜索引擎
  • 做任务兼职赚钱的网站国色天香站长工具
  • 网站建设 化工企业网络营销方案设计
  • 门户网站模板源代码济南seo关键词排名工具