文档章节

设计模式(Hibernate)

学而时习之
 学而时习之
发布于 2015/04/21 09:49
字数 1417
阅读 98
收藏 11

1、概述

2、面向对象设计原则

    1)单一职责原则

    2)开闭原则

    3)里氏替换原则

    4)依赖倒置原则

    5)接口隔离原则

     6)迪米特原则

    7)组合/聚合复用原则

3、设计模式

4、设计模式分类

5、简单工厂模式

 样例:

产品接口类(Product):

package com.ljb.simplefactory;
/**
 * 产品接口
 * @author LJB
 * @version 2015年4月21日
 */
public interface Product {
 /**产品生产工艺*/
 public void craftwork();
 
 /**产品特征*/
 public void type();
}

 产品类(鲜奶):

 package com.ljb.simplefactory;
/**
 * 鲜奶
 * @author LJB
 * @version 2015年4月21日
 */
public class Creamery implements Product {
 @Override
 public void craftwork() {
  System.out.println("牛奶+除菌=鲜奶");
 }
 @Override
 public void type() {
  System.out.println("原味浓香");
 }
}

产品类(酸奶):

package com.ljb.simplefactory;
/**
 * 酸奶
 * @author LJB
 * @version 2015年4月21日
 */
public class Yoghourt implements Product {
 @Override
 public void craftwork() {
  System.out.println("牛奶+酵母菌+糖=酸奶");
 }
 @Override
 public void type() {
  System.out.println("酸甜可口");
 }
}

简单工厂类:

package com.ljb.simplefactory;
/**
 * 静态工厂
 * @author LJB
 * @version 2015年4月21日
 */
public class StaticFactory {
 public static Product factory (String str) throws BadException {
  if (str.equalsIgnoreCase("creamery")) {
   System.out.println("生产鲜奶");
   return new Creamery();
  } else if (str.equalsIgnoreCase("yoghourt")) {
   System.out.println("生产酸奶");
   return new Yoghourt();
  } else {
   throw new BadException("没有此产品");
  }
 }
}

异常类:

package com.ljb.simplefactory;
/**
 * 自定义异常类
 * @author LJB
 * @version 2015年4月21日
 */
public class BadException extends Exception {
 public BadException (String msg) {
  super(msg);
 }
}

测试类:

package com.ljb.simplefactory;
/**
 * 测试类
 * @author LJB
 * @version 2015年4月21日
 */
public class Test {
 /**
  * @param args
  */
 public static void main(String[] args) {
  try {
   Product x = StaticFactory.factory("creamery");
   x.craftwork();
   x.type();
   Product y = StaticFactory.factory("yoghourt");
   y.craftwork();
   y.type();
  } catch (BadException e) {
   e.printStackTrace();
  }
  
 }
}

执行结果:

生产鲜奶
牛奶+除菌=鲜奶
原味浓香
生产酸奶
牛奶+酵母菌+糖=酸奶
酸甜可口

小结:

工厂需要知道多有产品

缺点:对开闭原则支持不够

6、工厂方法模式

 注:引入简单工厂模式中的产品接口及产品类

增加:

工厂接口(ProductFactory):

package com.ljb.factorymethod;
/**
 * 工厂接口类
 * @author LJB
 * @version 2015年4月21日
 */
public interface ProductFactory {
 public Product factory();
}

工厂实现类(鲜奶工厂):

package com.ljb.factorymethod;
/**
 * 鲜奶工厂
 * @author LJB
 * @version 2015年4月21日
 */
public class CreameryFactory implements ProductFactory {
 @Override
 public Product factory() {
  System.out.println("生产鲜奶");
  return new Creamery();
 }
}

工厂实现类(酸奶工厂):

package com.ljb.factorymethod;
/**
 * 酸奶工厂类
 * @author LJB
 * @version 2015年4月21日
 */
public class YoghourtFactory implements ProductFactory {
 @Override
 public Product factory() {
  System.out.println("生产酸奶");
  return new Yoghourt();
 }
}

测试类:

package com.ljb.factorymethod;
/**
 * 测试类
 * @author LJB
 * @version 2015年4月21日
 */
public class Test {
 /**
  * @param args
  */
 public static void main(String[] args) {
  ProductFactory y = new CreameryFactory();
  y.factory().craftwork();
  y.factory().type();
  ProductFactory x = new YoghourtFactory();
  x.factory().craftwork();
  x.factory().type();
 }
}

7、代理模式

 样例:

抽象主题:

package com.ljb.proxy;
/**
 * 抽象主题或者是接口
 * @author LJB
 * @version 2015年4月21日
 */
public abstract class Subject {
 /**
  * 声明一个抽象的请求方法
  */
 abstract public void request();
}

真实主题:

package com.ljb.proxy;
/**
 * 真是主题
 * @author LJB
 * @version 2015年4月21日
 */
public class RealSubject extends Subject {
 @Override
 public void request() {
  System.out.println("实现请求");
 }
}

代理主题:

package com.ljb.proxy;
/**
 * 代理主题(通过代理实现对真实主题的引用,并且可以加入自己的方法)
 * @author LJB
 * @version 2015年4月21日
 */
public class ProxySubject extends Subject {
 private RealSubject realSubject;
 
 @Override
 public void request() {
  preRequest();
  if (realSubject == null) {
   realSubject = new RealSubject();
  }
  realSubject.request();
  aftRequest();
 }
 
 public void preRequest() {
  System.out.println("请求前的方法");
 }
 
 public void aftRequest () {
  System.out.println("请求后的方法");
 }
}

测试类:

package com.ljb.proxy;
/**
 * 测试类
 * @author LJB
 * @version 2015年4月21日
 */
public class Test {
 /**
  * @param args
  */
 public static void main(String[] args) {
  Subject proxy = new ProxySubject();
  proxy.request();
 }
}

运行结果:

请求前的方法
实现请求
请求后的方法

8、策略(strategy)模式

样例:

策略抽象类(抽象账户):

package com.ljb.strategy;
/**
 * 抽象账户
 * @author LJB
 * @version 2015年4月21日
 */
public abstract class Account {
 /**
  * 计算产品的真实价格
  * @param amount
  * @param price
  * @return
  */
 public abstract float getFactPrice (int amount , int price);
}

策略实现类(普通账户):

package com.ljb.strategy;
/**
 * 普通客户商品价格计算类
 * @author LJB
 * @version 2015年4月21日
 */
public class CommonAccount extends Account {
 @Override
 public float getFactPrice(int amount, int price) {
  return amount*price;
 }
}

策略实现类(会员账户):

package com.ljb.strategy;
/**
 * 会员商品价格计算类
 * @author LJB
 * @version 2015年4月21日
 */
public class InsiderAccount extends Account {
 @Override
 public float getFactPrice(int amount, int price) {
  // TODO Auto-generated method stub
  return amount*price*9/10;
 }
}

策略实现类(VIP账户):

package com.ljb.strategy;
/**
 * vip会员商品价格计算类
 * @author LJB
 * @version 2015年4月21日
 */
public class VipAccount extends Account {
 @Override
 public float getFactPrice(int amount, int price) {
  // TODO Auto-generated method stub
  return amount*price*8/10;
 }
}

策略维护类:

package com.ljb.strategy;
/**
 * 此类用于维护策略类的引用
 * 各个算法封装起来,通过维护类实现对各个算法的引用
 * @author LJB
 * @version 2015年4月21日
 */
public class Context {
 /**持有策略类的引用*/
 private Account account;
 
 /**
  * 构造方法,实例化策略类的引用
  * 父类作为方法形参的使用方式
  * @param account
  */
 public Context (Account account) {
  this.account = account;
 }
 
 /**
  * 调用策略方法
  * @param amount
  * @param price
  * @return
  */
 public float doAccount (int amount , int price) {
  return account.getFactPrice(amount, price);
 }
}

测试类:

package com.ljb.strategy;
/**
 * 测试类
 * @author LJB
 * @version 2015年4月21日
 */
public class Test {
 /**
  * @param args
  */
 public static void main(String[] args) {
  String name = "CD唱片";
  int amount = 2;
  int price = 50;
  float sum = 0;
  
  // 普通客户
  Context common = new Context(new CommonAccount());
  sum = common.doAccount(amount, price);
  System.out.println("您是普通客户没有折扣,商品名称:" + name +
   "数量:" + amount + "价格:" + price + "应付金额:" + sum);
  
  // 会员客户
  Context insider = new Context(new InsiderAccount());
  sum = insider.doAccount(amount, price);
  System.out.println("您是会员享受9折优惠,商品名称:" + name +
   "数量:" + amount + "价格:" + price + "应付金额:" + sum);
  
  // VIP客户
  Context vip = new Context(new VipAccount());
  sum = vip.doAccount(amount, price);
  System.out.println("您是VIP会员享受8折优惠,商品名称:" + name +
   "数量:" + amount + "价格:" + price + "应付金额:" + sum);
 }
}

运行结果:

您是普通客户没有折扣,商品名称:CD唱片数量:2价格:50应付金额:100.0
您是会员享受9折优惠,商品名称:CD唱片数量:2价格:50应付金额:90.0
您是VIP会员享受8折优惠,商品名称:CD唱片数量:2价格:50应付金额:80.0

 

 

© 著作权归作者所有

共有 人打赏支持
学而时习之
粉丝 29
博文 93
码字总数 42877
作品 0
西安
编程中的那些套路——关于策略模式

该文章属于《编程中的那些经典套路——设计模式汇总》系列,并且以下内容基于语言PHP 今天讲讲策略模式,策略模式 和工厂模式十分相像(或者说在代码逻辑层面,他们是一样的)。 但策略模式与...

gzchen
08/27
0
0
javascript 设计模式之工厂(Factory)模式

工厂模式介绍 工厂模式是一个创建型的模式,主要就是创建对象。其中工厂模式又分为简单工厂模式和抽象工厂模式。简单工厂模式是通过工厂方法确定创建 对应类型的对象。抽象工厂模式是通过子类...

hlxiong
2014/04/14
0
0
JavaScript设计模式入坑

JavaScript设计模式入坑 介绍 设计模式编写易于维护的代码。 设计模式的开创者是一位土木工程师。Σ( ° △ °|||)︴,写代码就是盖房子。 模式 模式一种可以复用的解决方案。解决软件设计中...

小小小8021
10/18
0
0
java设计模式-- 单例模式

在很久之前,也就是在大二暑假的时候,那时候看马士兵的视频教程中有提到很多的设计模式。 java的设计模式大致可以分为3大类,23种设计模式。 其中,创建型模式有5种:单例模式、建造者模式、...

爱学习的逃课君
2014/11/27
0
0
代理模式(Proxy Pattern):动态代理 - 最易懂的设计模式解析

前言 今天我来全面总结开发中最常用的设计模式 - 代理模式中的动态代理模式 其他设计模式介绍 1分钟全面了解“设计模式” 单例模式(Singleton) - 最易懂的设计模式解析 简单工厂模式(Sim...

Carson_Ho
04/09
0
0

没有更多内容

加载失败,请刷新页面

加载更多

shell学习之创建函数

函数是一个脚本代码块,你可以为其命名并在代码中任何位置重用。 在bash shell脚本中创建函数基本使用如下两种方式,第二种格式更接近于其他编程语言中定义函数的方式。 function name {com...

woshixin
10分钟前
0
0
Toolfk.com 程序员工具网上线

#前言 真不容易,用了一个月的业余时间才把这个网站(toolfk.com)做完。里面的内容主要是从github上找的开源码码,在线运行使用的是Docker运行。当然也是现成的。因为我现在对Docker还是不懂。...

hihubs
23分钟前
0
0
svn 常用操作命令及问题处理

1. 常用命令 1.1. 基本使用 检出 checkout ➜ svn co repo_url -m '检出代码'➜ svn co repo_url saved_dir_name -m '检出代码,并指定目录名' 加入版本控制 add # 添加指定文件➜ svn...

whoru
50分钟前
3
0
记一次jquery validate的扩展(第一次失去焦点时触发校验)

最近在用jquery.validate 做前端表单校验,但是发现每次第一次失去焦点时,如果文本框内容为空,且该字段是必填项, 则不会触发校验,直到提交表单后,再次失去焦点时,才会触发,想对此进行...

foreach
55分钟前
1
0
java生成UUID

UUID介绍: UUID(Universally Unique Identifier)全局唯一标识符,是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。按照开放软件基金会(OSF)制定的标准计算,用到了以...

编程SHA
58分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部