策略模式java 用例_java策略模式简单用例

运用java策略模式一个小程序

/**

*

*/

package Strategy;

import java.util.Arrays;

/**

* @author HuangRong

* @Funtion 定义策略

*/

public interface ComputablesStra {

public abstract void printForm();

}

/**

*

*/

package Strategy;

/**

* @author HuangRong

* @Function 为策略模式中的上下文角色,

* 提供printLetter()方法调用具体策略所重写的方法

*/

public class ControlPrint {

ComputablesStra stra;

public void setStrategy(ComputablesStra stra){

this.stra=stra;

}

public void printLetter(){

stra.printForm();

}

}

/**

*

*/

package Strategy;

import java.util.Arrays;

/**

* @author HuangRong

* @Funtion 按照大写,小写穿插的方式输出26个英文字母的实现,

* 为具体策略

*/

public class Form1 implements ComputablesStra {

@Override

public void printForm() {

// TODO Auto-generated method stub

//int m;

for(char i='a';i<='z';i++){

System.out.print(i+",");

System.out.print ((char)(i-32));

if((char)(i-32)!='Z'){

System.out.print(",");

}

}

System.out.println (";");

}

}

package Strategy;

/**

* @author HuangRong

* @Funtion 按照先大写全部输出,再小写全部输出的方式输出26个英文字母的实现,

* 为具体策略

*/

public class Form2 implements ComputablesStra {

@Override

public void printForm() {

// TODO Auto-generated method stub

char i;

for(i='A';i<='Z';i++){

System.out.print(i);

if(i!='Z'){

System.out.print(",");

}

}

System.out.print(";");

for(i='a';i<='z';i++){

System.out.print(i);

if(i!='z'){

System.out.print(",");

}

}

System.out.println(";");

}

}

/**

*

*/

package Strategy;

/**

* @author HuangRong

* @Function 策略模式的使用

*/

public class PrintMain {

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

//上下文对象

ControlPrint print=new ControlPrint();

//上下文对象使用策略一

print.setStrategy(new Form1());

System.out.println("按照大写,小写穿插的方式输出26个英文字母:");

print.printLetter();

//上下文对象使用策略二

print.setStrategy(new Form2());

System.out.println("按照先大写全部输出,再小写全部输出的方式输出26个英文字母:");

print.printLetter();

}

}

0818b9ca8b590ca3270a3433284dd417.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/471544.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 2057. 值相等的最小索引

文章目录1. 题目2. 解题1. 题目 给你一个下标从 0 开始的整数数组 nums &#xff0c;返回 nums 中满足 i mod 10 nums[i] 的最小下标 i &#xff1b;如果不存在这样的下标&#xff0c;返回 -1 。 x mod y 表示 x 除以 y 的 余数 。 示例 1&#xff1a; 输入&#xff1a;num…

.net String.Format数字格式化输出

内容转载自&#xff1a;http://www.cnblogs.com/lqb/archive/2008/08/04/1259498.html 前面内容这个做的总结的很全&#xff0c;今后有新增的我继续往后补充。请留意我增加的绿色字体&#xff0c;有惊喜哟&#xff01;-:) int a 12345678; //格式为sring输出 Label1.Text str…

java a 2_Java A* 算法(2)

if(Arrays.binarySearch(isPass,map[fy][fx]) 0) { Node node2 new Node(fx, fy); node2.parent node; node2.G node.G 10; //采用manhattan启发算法 两点中的直角 距离 node2.H Math.abs((ex-fxey-fy)if(Arrays.binarySearch(isPass,map[fy][fx]) > 0)  {Node node…

LeetCode 2058. 找出临界点之间的最小和最大距离(链表)

文章目录1. 题目2. 解题1. 题目 链表中的 临界点 定义为一个 局部极大值点 或 局部极小值点 。 如果当前节点的值 严格大于 前一个节点和后一个节点&#xff0c;那么这个节点就是一个 局部极大值点 。 如果当前节点的值 严格小于 前一个节点和后一个节点&#xff0c;那么这个…

LeetCode 2059. 转化数字的最小运算数(BFS)

文章目录1. 题目2. 解题1. 题目 给你一个下标从 0 开始的整数数组 nums &#xff0c;该数组由 互不相同 的数字组成。另给你两个整数 start 和 goal 。 整数 x 的值最开始设为 start &#xff0c;你打算执行一些运算使 x 转化为 goal 。你可以对数字 x 重复执行下述运算&…

java8 supplyasync_java – 为什么CompletableFuture.supplyAsync成功随...

我是Java 8中lambda和异步代码的新手.我不断得到一些奇怪的结果……我有以下代码&#xff1a;import java.util.concurrent.CompletableFuture;public class Program {public static void main(String[] args) {for (int i 0; i < 100; i) {String test "Test_"…

又是一年国庆假期最后一天

时间过的真的很快啊&#xff0c;美好的日子已经快过完了&#xff0c;在长假的最后一天&#xff0c;有很多的朋友可能都会抱怨&#xff0c;不想上班了&#xff0c;好想在好好的玩玩。开开心心的过完了假期的前六天&#xff0c;当突然被告知明天就是最后一天&#xff0c;你会有什…

LeetCode 2062. 统计字符串中的元音子字符串

文章目录1. 题目2. 解题1. 题目 子字符串 是字符串中的一个连续&#xff08;非空&#xff09;的字符序列。 元音子字符串 是 仅 由元音&#xff08;a、e、i、o 和 u&#xff09;组成的一个子字符串&#xff0c;且必须包含 全部五种 元音。 给你一个字符串 word &#xff0c;…

1006实验一实验报告

实验一报告 实验一、DOS命令解释程序的编写 13物联网工程 张学玲 201306104140 一、 实验目的 &#xff08;1&#xff09;认识DOS&#xff1b; &#xff08;2&#xff09;掌握命令解释程序的原理&#xff1b; &#xff08;3&#xff09;掌握简单的DOS调用方法&#xff1b; &a…

LeetCode 2063. 所有子字符串中的元音(数学)

文章目录1. 题目2. 解题1. 题目 给你一个字符串 word &#xff0c;返回 word 的所有子字符串中 元音的总数 &#xff0c;元音是指 a、e、i、o 和 u 。 子字符串 是字符串中一个连续&#xff08;非空&#xff09;的字符序列。 注意&#xff1a;由于对 word 长度的限制比较宽松…

java8 util.time_Java8 java.util.Date转换为java.time.ZonedDateTime

尝试将java.util.Date转换为java.time.LocalDate时&#xff0c;我收到以下异常。java.time.DateTimeException: Unable to obtain ZonedDateTime from TemporalAccessor: 2014-08-19T05:28:16.768Z of type java.time.Instant代码如下&#xff1a;public static Date getNeares…

Android Intent

Android手机软件开发中&#xff0c;Intent作为手机软件开发时很重要的对象需要引起我们的重视&#xff0c;实际上&#xff0c;intent也是体现Android开发具有其独特性的一个标志性的对象。 当一个Activity要启动另外一个Activity的时候&#xff0c;也许一个以前较为熟悉的模式是…

LeetCode 2064. 分配给商店的最多商品的最小值(二分查找)

文章目录1. 题目2. 解题1. 题目 给你一个整数 n &#xff0c;表示有 n 间零售商店。 总共有 m 种产品&#xff0c;每种产品的数目用一个下标从 0 开始的整数数组 quantities 表示&#xff0c;其中 quantities[i] 表示第 i 种商品的数目。 你需要将 所有商品 分配到零售商店&a…

Java 远程mapduce_java – 如何远程运行mapreduce作业

当我尝试远程运行map-reduce作业(字数计数示例)时遇到了一些问题.我搜索谷歌后仍然无法实现我的目标.我刚刚看到很少关于远程调用map-reduce作业的主题.以下是问题&#xff1a;>首先,我遇到许可问题&#xff1a;SEVERE: PriviledgedActionException as:[user] cause:org.apa…

LeetCode 2065. 最大化一张图中的路径价值(DFS)

文章目录1. 题目2. 解题1. 题目 给你一张 无向 图&#xff0c;图中有 n 个节点&#xff0c;节点编号从 0 到 n - 1 &#xff08;都包括&#xff09;。 同时给你一个下标从 0 开始的整数数组 values &#xff0c;其中 values[i] 是第 i 个节点的 价值 。同时给你一个下标从 0 开…

java第九章编写一个能够产生_第九章java教程.ppt

第九章java教程5、下面哪个选项能够构造一个BufferedInputStream流&#xff1f;() A. New BufferedInputStream(“in.txt”); B. New BufferedInputStream(new File(“in.txt”)); C. New BufferedInputStream(new Write(“in.txt”)); D. New BufferedInputStream(new InputSt…

hello nodejs

文章1一步&#xff1a;下载、安装文件 打开nodejs官方网站http://www.nodejs.org/download/ 。选择须要的版本号。直接打开。默认安装就可以 第二步&#xff1a;编写測试代码: var http require(http); http.createServer(function(req, res) {res.writeHead(200, {Content-Ty…

LeetCode 1739. 放置盒子(数学)

文章目录1. 题目2. 解题1. 题目 有一个立方体房间&#xff0c;其长度、宽度和高度都等于 n 个单位。 请你在房间里放置 n 个盒子&#xff0c;每个盒子都是一个单位边长的立方体。放置规则如下&#xff1a; 你可以把盒子放在地板上的任何地方。如果盒子 x 需要放置在盒子 y 的…

java 线程池的理解_JAVA线程池原理的理解

线程池原理基础理解&#xff1a;线程池初始化规定个数的线程&#xff0c;然后这些线程一直运行&#xff0c;并且监控线程队列&#xff0c;只要线程队列被添加进线程&#xff0c;那么线程池不断从队列中取出线程运行。直到队列中的线程为空。实例代码如下&#xff1a;package xi…

Linux什么时候在pc机上有一席之地

这样一个题目&#xff0c;或许会让很多linux粉丝们感到很失望&#xff0c;linux在粉丝们眼里&#xff0c;已经是开源&#xff0c;自由软件&#xff0c;反抗微软暴政的等同词。但是linux在个人电脑领域&#xff0c;确实已经面临鸡肋的局面&#xff0c;未来的发展&#xff0c;即使…