SC || Chapter 5 复习向
可复用性
┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉
行为子结构
对于父子的继承关系的要求:
·子类可以增加方法,但不可以删
·子类需实现抽象类型中未实现的方法
·子类重写(override)的方法必须有相同的返回值和参数列表
·子类不能抛出额外的异常
对于具体的方法:
·更强的不变量
·更弱的前置条件
·更强的后置条件
┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉
协变与逆变
协变:从父类型到子类型,返回值或异常的类型不变或变得更具体
逆变:从父类型到子类型,参数变得越来越抽象(不允许)
不变:只是重写了方法
┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉
【LSP】
子类可以扩展父类的功能,但不能修改父类原有的功能
子类可以有自己的个性
子类覆盖或实现父类的方法时输入参数可以变抽象,返回值变具体
(留坑)
┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉
子类只需要复用父类中的一小部分方法,可以不需要通过继承,而通过委派来完成
组合的例子:
对于不同的子类对象,委派能计算它的奖金的方法,就不需要在子类继承的时候每个子类里都进行重写
┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉
【可复用的设计模式】
- 结构型模式:Structural patterns
- 适配器模式(Adapter)
- 装饰器模式(Decorator )
- 外观模式(Facade)
- 行为类模式:Behavioral patterns
- 策略模式(Strategy)
- 模板方法模式(Template method)
- 迭代器模式( Iterator)
┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉
结构型模式:
适配器模式 Adaptor
增加一个接口,将已存在的子类封装起来,client面向接口编程
装饰器模式 Decorator
替代继承,向一个现有的类中添加新的功能
这种模式创建了一个装饰类,用来包装原有的类
Stack s = new ArrayStack(); //构建一个普通的堆栈
UndoStack s = new UndoStack(new ArrayStack()); //构建撤消堆栈
SecureStack s = new SecureStack( new SynchronizedStack( new UndoStack(s)))//构建安全的同步撤消堆栈
这样一层层的实现就是Decorator模式
外观模式 Facade
提供一个统一的接口来代替小接口的调用,相当于对复杂系统做了封装,供客户端简洁的使用
┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉
行为型模式:
策略模式 Strategy
创建表示各种模式的对象和一个行为随着不同对象策略而改变的context,策略对象改变context执行的算法
public interface AStrategy {
public abstract a();
}
// 一个策略对象
public class B implements AStrategy { // 还可以有 C D 等等不同的策略对象
// fields
// Constructor
@Override
public double a() {
// 不同的策略对象这里不一样
}
} public class AContext {
public double a(AStrategy aStrategy) {
return aStrategy.a();
}
} public class Main {
AContext context = new AContext();
double ans = context.a(new AStrategy() {});
}
模板模式 Template
抽象类定义执行它的方法/模式,子类按照需要重写方法,但调用以抽象类中的方法调用
public abstract class Edge {
// fields
public abstract boolean a();
} public class DirectedEdge extends Edge {
// different fields //constructor @Override
public boolean a() {
// method
}
}
迭代器模式 Iterator
顺序访问集合对象中的元素,又不暴露对象的内部表示
让集合类实现Iterable接口,重写 next(), hasNext(), remove()
感谢神仙!!!https://www.cnblogs.com/hithongming/p/8481372.html
SC || Chapter 5 复习向的更多相关文章
- SC || Chapter 8
栈:方法调用和局部变量的存储位置,保存基本类型 堆:在一块内存里分为多个小块,每块包含 一个对象,或者未被占用
- SC || Chapter 3
┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉ 基本数据类型 && 对象数据类型 基本数据类型(int char long) 在栈中分配内存,不可变 对象数据类型(String BigInt ...
- SC || Chapter 1
第一章的重中之重就是这张图吧 (具体参见笔记) ┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉┉∞ ∞┉┉┉∞ ∞┉┉ 区分哪些属性是外部的(面向用户 ...
- SC || Chapter6 复习向 面向可维护性 我哭了
高内聚低耦合 高内聚:一个模块内部各个元素彼此结合的紧密程度,一个软件模块是由相关性很强的代码组成,只负责一项任务,也就是常说的单一责任原则 低耦合:各模块间相互联系紧密程度,模块间接口的复杂性.调用 ...
- HDOJ(HDU) 2078 复习时间
Problem Description 为了能过个好年,xhd开始复习了,于是每天晚上背着书往教室跑.xhd复习有个习惯,在复习完一门课后,他总是挑一门更简单的课进行复习,而他复习这门课的效率为两门课 ...
- USACO Chapter 1 解题总结
USACO Chapter 1 解题总结 1.1.1 Your Ride Is Here 基本字符串操作,无压力. 1.1.2 Greedy Gift Givers 基础模拟题,弄明白题意,不怕麻烦, ...
- sql语法复习:增删查改,各种数据库对象创建和函数使用
推荐工具:机子配置较低的话,可以装Gsql这个工具获得sql执行环境(可作为手册查看内置数据类型 函数和存储过程等) --之前数据库的东西接触不多,虽然基本的语法是了解,但不是很熟悉--最近项目一直在 ...
- Professional C# 6 and .NET Core 1.0 - Chapter 39 Windows Services
本文内容为转载,供学习研究.如有侵权,请联系作者删除. 转载请注明本文出处:Professional C# 6 and .NET Core 1.0 - Chapter 39 Windows Servi ...
- Chapter 3. Programming with RDDs
Programming with RDDs This chapter introduces Spark's core abstraction for working with data, the r ...
随机推荐
- 51nod1186(Miller-Rabin)
题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1186 题意:中文题目诶- 思路:miller_rabin模板 ...
- 洛谷P3434 [POI2006]KRA-The Disks
P3434 [POI2006]KRA-The Disks 题目描述 For his birthday present little Johnny has received from his paren ...
- 2014-10-6 NOIP模拟赛
1. 锻炼计划(exercise.pas) 身体是革命的本钱,OIers不要因为紧张的学习和整天在电脑前而忽视了健康问题.小x设计了自己的锻炼计划,但他不知道这个计划是否可行,换句话说如果计划不当可能 ...
- SpringBoot2.0 基础案例(11):配置AOP切面编程,解决日志记录业务
本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.AOP切面编程 1.什么是AOP编程 在软件业,AOP为Asp ...
- java 文件相关问题
1.文件路径 分隔符 System.out.println(File.separator); System.out.println(File.pathSeparator); /*mac os 和 li ...
- java.exe is valid, but is for a machine type other than the current machine
java.exe is valid, but is for a machine type other than the current machine jdk版本不一致问题,在32位机器上使用64位的 ...
- nutzboot 使用nacos替换zookeeper
先放一段从网上拷贝一段分布式CAP理论的概念 分布式领域中存在CAP理论,且该理论已被证明:任何分布式系统只可同时满足两点,无法三者兼顾. ①C:Consistency,一致性,数据一致更新,所有数据 ...
- Python内建函数二
内置函数二: 1.lambda (匿名函数) 为了解决一些简答的需求而设计的一句话函数.不需要def来声明. def func(n): return n*n f = lambda n: n*n 注意: ...
- hdu5036 Explosion 传递闭包
大哲哥的讲课内容 根据期望的线性性,得到总期望为各个点被轰的概率(不会证,好像是这样吧) 传递闭包解决出每个点的祖先(能到达它的点)就能算概率了 bitset能贡献1/w的复杂度,而且导致Floyd只 ...
- Canada Cup 2016 C. Hidden Word 构造模拟题
http://codeforces.com/contest/725/problem/C Each English letter occurs at least once in s. 注意到题目有这样一 ...