文档章节

设计模式(Hibernate)

学而时习之
 学而时习之
发布于 2015/04/21 09:49
字数 1417
阅读 97
收藏 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
西安
javascript 设计模式之工厂(Factory)模式

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

hlxiong
2014/04/14
0
0
java设计模式-- 单例模式

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

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

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

Carson_Ho
04/09
0
0
【设计模式笔记】(十六)- 代理模式

一、简述 代理模式(Proxy Pattern),为其他对象提供一个代理,并由代理对象控制原有对象的引用;也称为委托模式。 其实代理模式无论是在日常开发还是设计模式中,基本随处可见,中介者模式中...

MrTrying
06/24
0
0
JavaScript 中常见设计模式整理

开发中,我们或多或少地接触了设计模式,但是很多时候不知道自己使用了哪种设计模式或者说该使用何种设计模式。本文意在梳理常见设计模式的特点,从而对它们有比较清晰的认知。 JavaScript 中...

牧云云
05/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

(一)软件测试专题——之Linux常用命令篇01

本文永久更新地址:https://my.oschina.net/bysu/blog/1931063 【若要到岸,请摇船:开源中国 不最醉不龟归】 Linux的历史之类的很多书籍都习惯把它的今生来世,祖宗十八代都扒出来,美其名曰...

不最醉不龟归
15分钟前
3
0
蚂蚁金服Java开发三面

8月20号晚上8点进行了蚂蚁金服Java开发岗的第三面,下面开始: 自我介绍(要求从实践过程以及技术背景角度着重介绍) 实习经历,说说你在公司实习所做的事情,学到了什么 关于你们的交易平台...

edwardGe
21分钟前
7
0
TypeScript基础入门 - 函数 - this(三)

转载 TypeScript基础入门 - 函数 - this(三) 项目实践仓库 https://github.com/durban89/typescript_demo.gittag: 1.2.4 为了保证后面的学习演示需要安装下ts-node,这样后面的每个操作都能...

durban
31分钟前
0
0
Spark core基础

Spark RDD的五大特性 RDD是由一系列的Partition组成的,如果Spark计算的数据是在HDFS上那么partition个数是与block数一致(大多数情况) RDD是有一系列的依赖关系,有利于Spark计算的容错 RDD中每...

张泽立
39分钟前
0
0
如何搭建Keepalived+Nginx+Tomcat高可用负载均衡架构

一.概述 初期的互联网企业由于业务量较小,所以一般单机部署,实现单点访问即可满足业务的需求,这也是最简单的部署方式,但是随着业务的不断扩大,系统的访问量逐渐的上升,单机部署的模式已...

Java大蜗牛
53分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部