1.单例模式(有的书上说叫单态模式其实都一样)
该模式主要目的是使内存中保持1个对象。看下面的例子:
package org.sp.singleton;
//方法一
public class Singleton {
//将自身的实例对象设置为一个属性,并加上Static和final修饰符
private static final Singleton instance = new Singleton();
//将构造方法设置成私有形式
private Singleton() {
}
//通过一个静态方法向外界提供这个类的实例
public static Singleton getInstance() {
return instance;
}
}
//方法二
class Singleton2 {
private static Singleton2 instance2 = null;
public static synchronized Singleton2 getInstance() {
if (instance2 == null)
instance2 = new Singleton2();
return instance2;
}
}
注:这二个方法实现了一样的功能,但个人推荐采用第一种方法。
2.工厂模式
该模式主要功能是统一提供实例对象的引用。看下面的例子:
public class Factory{
public ClassesDao getClassesDao(){
ClassesDao cd = new ClassesDaoImpl();
return cd;
}
}
interface ClassesDao{
public String getClassesName();
}
class ClassesDaoImpl implements ClassesDao {
public String getClassesName(){
System.out.println("A班");
}
}
class test
{
public static void main(String[] args){
Factory f = new Factory();
f.getClassesDao().getClassesName();
}
}
这个是最简单的例子了,就是通过工厂方法通过接口获取对象的引用
3.建造模式
该模式其实就是说,一个对象的组成可能有很多其他的对象一起组成的,比如说,一个对象的实现非常复杂,有很多的属性,而这些属性又是其他对象的引用,可能这些对象的引用又包括很多的对象引用。封装这些复杂性,就可以使用建造模式。
4.门面模式
这个模式个人感觉像是Service层的一个翻版。比如Dao我们定义了很多持久化方法,我们通过Service层将Dao的原子方法组成业务逻辑,再通过方法向上层提供服务。门面模式道理其实是一样的。
具体看看这个例子:
interface ClassesDao{
public String getClassesName();
}
class ClassesDaoImpl implements ClassesDao {
public String getClassesName(){
return "A班";
}
}
interface ClassesDao2{
public String getClassesName();
}
class ClassesDaoImpl2 implements ClassesDao {
public String getClasses2Name(){
return "B班";
}
}
class ServiceManager
{
private ClassesDao cd = new ClassesDaoImpl();
private ClassesDao2 cd2 = new ClassesDaoImpl2();
public void printOut(){
System.out.println(cd.getClassesName()+" "+cd2.getClassesName());
}
};
虽然这个例子不全,但基本意思已经很明显了。
5.策略模式
这个模式是将行为的抽象,即当有几个类有相似的方法,将其中通用的部分都提取出来,从而使扩展更容易。
看这个例子:
package org.sp.strategy;
/**
* 加法具体策略类
* @author 无尽de华尔兹
*
*/
public class Addition extends Operation {
@Override
public float parameter(float a, float b) {
return a+b;
}
}
package org.sp.strategy;
/**
* 除法具体策略类
* @author 无尽de华尔兹
*
*/
public class Division extends Operation {
@Override
public float parameter(float a, float b) {
return a/b;
}
}
package org.sp.strategy;
/**
* 乘法具体策略类
* @author 无尽de华尔兹
*
*/
public class Multiplication extends Operation{
@Override
public float parameter(float a, float b) {
return a*b;
}
}
package org.sp.strategy;
/**
* 减法具体策略类
* @author 无尽de华尔兹
*
*/
public class Subtration extends Operation {
@Override
public float parameter(float a, float b) {
return a-b;
}
}
package org.sp.strategy;
/**
* 抽象策略类也可以使用接口来代替
* @author 无尽de华尔兹
*
*/
public abstract class Operation {
public abstract float parameter(float a, float b);
}
package org.sp.strategy;
/**
* 策略环境类
* @author 无尽de华尔兹
*
*/
public class Condition {
public static final Addition add = new Addition();
public static final Subtration sub = new Subtration();
public static final Multiplication mul = new Multiplication();
public static final Division div = new Division();
}
package org.sp.strategy;
/**
* 测试客户端
* @author 无尽de华尔兹
*
*/
public class Client {
public static void main(String[] args) {
float a = 100;
float b = 25;
System.out.println(Condition.div.parameter(a, b));
}
}
Java中几个常用设计模式
发表于:2017-08-08
作者:网络转载
来源:
 相关文章
聊聊架构设计流程:设计备选方案 Java中的并发编程模型及其应对策略 掌握Java并发编程,避免无处不在的竞态条件 2024年,五个Java开发者应该关注的编程趋势 解除Java反复编译的困扰方法,优化开发效率 改善代码质量,试试这十种方法- 周排行
- 月排行
- 评论排行
-   高效IT:如何利用零代码开发平台快速...
-   一体化好好的,为什么要前后端分离?
-   13种最佳App设计不止有设计美感,更跟...
-   12张图带你彻底理解分布式事务产生的...
-   2023 年 Java 发展趋势
-   Web3应和Web2一样用JavaScript构建
-   表明你的软件应该进行重大更新的11个迹象
-   一体化好好的,为什么要前后端分离?
-   高效IT:如何利用零代码开发平台快速...
-   2024年最具潜力的十大编程语言:引领...
-   Spring Boot是Java程序员的必备技能...
-   2018年最全的App设计资源(工具+模板...
-   智能可穿戴设备的主要测试步骤
-   13种最佳App设计不止有设计美感,更跟...
-   从软件出发,非功能测试思考总结
-   展望2017,谁是网络技术头牌?
-   C/C++单元测试工具Visual Unit 4 介绍
-   国内外最好用的6款Bug跟踪管理系统
-   性能测试指标评估必读
-   百度软件测试方案模板
-   38张史上最全的IT工程师技能图谱
-   C/C++单元测试工具Visual Unit 4 介绍
-   2019年,你会选哪些安全测试工具?
-   十款Web服务器性能压力测试工具
-   软件测试入门指南:周期、模型和文档化
-   记自动化测试成神学习之路
-   软件测试全景图 -最全的思维导图