1    代码演练

1.1  继承关系判别(是否是真正意义的继承)

1.2  入参控制

1.3  出参控制

1    代码演练

1.1  继承关系判别(是否是真正意义的继承)(其实我觉得这个例子有点牵强)

1.1.1  反例

结论:

确定继承关系的时候一定要判断好,是否父类的方法子类可以继承。传统意义的正方形是矩形的子类,在这里是不适用的。

测试类1:

package com.geely.design.principle.liskovSubstitutation;

public class TestSquare {
public static void resize(Rectangle rectangle){
while(rectangle.getWidth()<=rectangle.getLength()){
rectangle.setWidth(rectangle.getWidth()+1);
System.out.println("长为"+rectangle.getLength()+"****************宽为"+rectangle.getWidth());
} }
public static void main(String [] args){
Rectangle rectangle = new Rectangle();
rectangle.setWidth(10);
rectangle.setLength(20);
resize(rectangle);
} // public static void main(String [] args){
// Square square = new Square();
// square.setLength(10);
// resize(square);
// }
}

打印结果1:

"C:\Program Files\Java\jdk1.6.0_43\bin\java.exe" "-javaagent:D:\java\devolopKit\idea\anZh\IntelliJ IDEA Community Edition 2018.1.4\lib\idea_rt.jar=17363:D:\java\devolopKit\idea\anZh\IntelliJ IDEA Community Edition 2018.1.4\bin" -Dfile.encoding=UTF-8 -classpath "C:\Program Files\Java\jdk1.6.0_43\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\jce.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\resources.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\rt.jar;F:\xiangmu3\Xin\Idea\out\production\design_pattern" com.geely.design.principle.liskovSubstitutation.TestSquare
长为20****************宽为11
长为20****************宽为12
长为20****************宽为13
长为20****************宽为14
长为20****************宽为15
长为20****************宽为16
长为20****************宽为17
长为20****************宽为18
长为20****************宽为19
长为20****************宽为20
长为20****************宽为21 Process finished with exit code 0

测试类2:

package com.geely.design.principle.liskovSubstitutation;

public class TestSquare {
public static void resize(Rectangle rectangle){
while(rectangle.getWidth()<=rectangle.getLength()){
rectangle.setWidth(rectangle.getWidth()+1);
System.out.println("长为"+rectangle.getLength()+"****************宽为"+rectangle.getWidth());
} }
// public static void main(String [] args){
// Rectangle rectangle = new Rectangle();
// rectangle.setWidth(10);
// rectangle.setLength(20);
// resize(rectangle);
// } public static void main(String [] args){
Square square = new Square();
square.setLength(10);
resize(square);
}
}

打印结果2:

**************************************
长为241350****************宽为241350
长为241351****************宽为241351
长为241352****************宽为241352
长为241353****************宽为241353
长为241354****************宽为241354
**************************************

矩形类:

package com.geely.design.principle.liskovSubstitutation;

public class Rectangle {
private long length;
private long width; public long getLength() {
return length;
} public void setLength(long length) {
this.length = length;
} public long getWidth() {
return width;
} public void setWidth(long width) {
this.width = width;
}
}

正方形类:

package com.geely.design.principle.liskovSubstitutation;

public class Square extends Rectangle {
private long sideLength; public long getSideLength() {
return sideLength;
} public void setSideLength(long sideLength) {
this.sideLength = sideLength;
} @Override
public long getLength() {
return getSideLength();
} @Override
public void setLength(long length) {
setSideLength(length);
} @Override
public long getWidth() {
return getSideLength();
} @Override
public void setWidth(long width) {
setSideLength(width);
}
}

1.1.2  正方形矩形实现四边形

结论:

子类行为规则应与父类行为规则一致,如果子类达不到这一点,则会违背里氏替换原则,违背里氏替换原则会怎样?继承逻辑混乱,代码不便于维护

测试类:

package com.geely.design.principle.liskovSubstitutation;

public class TestSquare2 {
public static void resize(Rectangle rectangle){
while(rectangle.getWidth()<=rectangle.getLength()){
rectangle.setWidth(rectangle.getWidth()+1);
System.out.println("长为"+rectangle.getLength()+"****************宽为"+rectangle.getWidth());
} }
// public static void main(String [] args){
// Rectangle rectangle = new Rectangle();
// rectangle.setWidth(10);
// rectangle.setLength(20);
// resize(rectangle);
// } public static void main(String [] args){
Square square = new Square();
square.setSideLength(10);
resize(square);
}
}

四边形接口:

package com.geely.design.principle.liskovSubstitutation;

public interface Quadrangle {
long getWidth();
long getLength();
}

矩形类:

package com.geely.design.principle.liskovSubstitutation;

public class Rectangle implements Quadrangle{
private long length;
private long width; public void setLength(long length) {
this.length = length;
} public void setWidth(long width) {
this.width = width;
} @Override
public long getWidth() {
return width;
} @Override
public long getLength() {
return length;
}
}

正方形类:

package com.geely.design.principle.liskovSubstitutation;

public class Square implements Quadrangle{
private long sideLength; public long getSideLength() {
return sideLength;
}
public void setSideLength(long sideLength) {
this.sideLength = sideLength;
} @Override
public long getWidth() {
return sideLength;
} @Override
public long getLength() {
return sideLength;
}
}

1.2  入参控制

1.2.1  里氏替换原则正例

结论:

重载的时候入参更加宽松,可以不引起逻辑的混乱。

测试类:

package com.geely.design.principle.liskovSubstitutation.inputmethod;

import java.util.HashMap;

public class TestChild {
public static void main(String [] args){
Child child = new Child();
HashMap hashMap = new HashMap();
child.method(hashMap);
}
}

子类:

import java.util.HashMap;
import java.util.Map; public class Child extends Base{
// @Override
// public void method(HashMap hashMap) {
// System.out.println("执行子类的HashMap方法");
// } /**
* 子类重载
* 重载的时候入参 Map比 Hashmap宽松,此时执行的时候会执行父类,不执行重载的类
* @param hashMap
*/
public void method(Map Map) {
System.out.println("执行子类Map方法");
}
}

父类:

package com.geely.design.principle.liskovSubstitutation.inputmethod;

import java.util.HashMap;

public class Base {
public void method(HashMap hashMap){
System.out.println("执行父类HashMap方法");
} }

打印结果:

"C:\Program Files\Java\jdk1.6.0_43\bin\java.exe" "-javaagent:D:\java\devolopKit\idea\anZh\IntelliJ IDEA Community Edition 2018.1.4\lib\idea_rt.jar=21089:D:\java\devolopKit\idea\anZh\IntelliJ IDEA Community Edition 2018.1.4\bin" -Dfile.encoding=UTF-8 -classpath "C:\Program Files\Java\jdk1.6.0_43\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\jce.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\resources.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\rt.jar;F:\xiangmu3\Xin\Idea\out\production\design_pattern" com.geely.design.principle.liskovSubstitutation.inputmethod.TestChild
执行父类HashMap方法 Process finished with exit code 0

1.2.2  里氏替换原则反例

测试类:

package com.geely.design.principle.liskovSubstitutation.inputmethod;

import java.util.HashMap;

public class TestChild {
public static void main(String [] args){
Child child = new Child();
HashMap hashMap = new HashMap();
child.method(hashMap);
}
}

子类:

package com.geely.design.principle.liskovSubstitutation.inputmethod;

import java.util.HashMap;
import java.util.Map; public class Child extends Base{
// @Override
// public void method(Map map) {
// super.method(map);
// } public void method(HashMap hashMap) {
System.out.println("执行子类HashMap方法");
}
}

父类:

package com.geely.design.principle.liskovSubstitutation.inputmethod;

import java.util.HashMap;
import java.util.Map; public class Base {
public void method(Map map){
System.out.println("执行父类HashMap方法");
} }

打印日志:

"C:\Program Files\Java\jdk1.6.0_43\bin\java.exe" "-javaagent:D:\java\devolopKit\idea\anZh\IntelliJ IDEA Community Edition 2018.1.4\lib\idea_rt.jar=21674:D:\java\devolopKit\idea\anZh\IntelliJ IDEA Community Edition 2018.1.4\bin" -Dfile.encoding=UTF-8 -classpath "C:\Program Files\Java\jdk1.6.0_43\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\jce.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\resources.jar;C:\Program Files\Java\jdk1.6.0_43\jre\lib\rt.jar;F:\xiangmu3\Xin\Idea\out\production\design_pattern" com.geely.design.principle.liskovSubstitutation.inputmethod.TestChild
执行子类HashMap方法 Process finished with exit code 0

1.3  出参控制

1.3.1  反例

结论:

子类的出参如果包含父类,会直接报错。

子类:

package com.geely.design.principle.liskovSubstitutation.outputmethod;

import java.util.Map;

public class Child extends Base {
@Override
public Object method() {
return null;
}
}

父类:

package com.geely.design.principle.liskovSubstitutation.outputmethod;

import java.util.Map;

public abstract class Base {
public abstract Map method();
}

设计模式课程 设计模式精讲 3-10 里氏替换原则coding的更多相关文章

  1. 北风设计模式课程---里氏替换原则(Liskov Substitution Principle)

    北风设计模式课程---里氏替换原则(Liskov Substitution Principle) 一.总结 一句话总结: 当衍生类能够完全替代它们的基类时:(Liskov Substitution P ...

  2. &quot;围观&quot;设计模式(2)--里氏替换原则(LSP,Liskov Substitution Principle)

    在面向对象的程序设计中.里氏替换原则(Liskov Substitution principle)是对子类型的特别定义.它由芭芭拉·利斯科夫(Barbara Liskov)在1987年在一次会议上名为 ...

  3. Java设计模式(4:里氏替换原则和合成复用原则详解

    一.里氏替换原则 如果说实现开闭原则的关键步骤就是抽象化,那么基类(父类)和子类的继承关系就是抽象化的具体实现,所以里氏替换原则就是对实现抽象化的具体步骤的规范.即:子类可以扩展基类(父类)的功能,但 ...

  4. ZT 设计模式六大原则(2):里氏替换原则

    设计模式六大原则(2):里氏替换原则 分类: 设计模式 2012-02-22 08:46 23330人阅读 评论(41) 收藏 举报 设计模式class扩展string编程2010 肯定有不少人跟我刚 ...

  5. [设计模式]<<设计模式之禅>>关于里氏替换原则

    在面向对象的语言中,继承是必不可少的.非常优秀的语言机制,它有如下优点:● 代码共享,减少创建类的工作量,每个子类都拥有父类的方法和属性:● 提高代码的重用性:● 子类可以形似父类,但又异于父类,“龙 ...

  6. 设计模式值六大原则——里氏替换原则(LSP)

    里氏替换原则(Liskov Substitution Principel)是解决继承带来的问题. 继承的优点: 代码共享,减少创建类的工作量,每个子类都拥有父类的方法和属性: 提高代码的重用性: 子类 ...

  7. 设计模式六大原则(2):里氏替换原则(Liskov Substitution Principle)

    肯定有不少人跟我刚看到这项原则的时候一样,对这个原则的名字充满疑惑.事实上原因就是这项原则最早是在1988年,由麻省理工学院的一位姓里的女士(Barbara Liskov)提出来的. 定义1:假设对每 ...

  8. 【设计模式六大原则2】里氏替换原则(Liskov Substitution Principle)

      肯定有不少人跟我刚看到这项原则的时候一样,对这个原则的名字充满疑惑.其实原因就是这项原则最早是在1988年,由麻省理工学院的一位姓里的女士(Barbara Liskov)提出来的. 定义1:如果对 ...

  9. 设计模式原则(2)--Liskov Substitution Principle(LSP)--里氏替换原则

    1.定义: 所有引用基类(父类)的地方必须能透明地使用其子类的对象.这一原则与继承紧密相关.如果对每一个类型为 T1的对象 o1,都有类型为 T2 的对象o2,使得以 T1定义的所有程序 P 在所有的 ...

随机推荐

  1. 【原】docker基础(一)

    1.架构 2.说明 Docker daemon( Docker守护进程):Docker daemon是一个运行在宿主机( DOCKER-HOST)的后台进程.可通过 Docker客户端与之通信. Cl ...

  2. MVC简要介绍

    (转自:http://www.cnbeta.com/articles/107924.htm) MVC不是一种设计模式(design pattern),它是一种架构模式(Architectural pa ...

  3. deepin-wine-qq无法加载图片解决方案

    最近在qq水群讨论学术的时候发现了一个奇怪的问题:无法加载图片. 具体点是,如果图片没有被其他设备接收,并且在缓存中,图片是可以加载的,反之不可. 这东西很烦人啊,于是我就去查项目issue:http ...

  4. Sublime Text3搭建完美开发环境(Python+PHP+Javascript+nodejs+C++)

    一.Sublime配置(如已安装Package Control可跳过) sublime下载地址:http://www.sublimetext.com/3 安装Package Control插件: 直接 ...

  5. 粪发涂墙-tomcat

    tomcat 的 JAVA_OPTS 分析设置 快乐生活你我 2019-08-12 06:07:00 JAVA_OPTS ,顾名思义,是用来设置JVM相关运行参数的变量. 1.JVM:JAVA_OPT ...

  6. Java日期时间API系列21-----Jdk8中java.time包中的新的日期时间API类,xk-time时间转换,计算,格式化,解析的工具

    通过工作之余,对Java8中java.time包源码的不断学习,使用和总结,开发了xk-time,初步完成,欢迎试用和提出建议! xk-time xk-time is a datetime conve ...

  7. Azure虚拟机网站部署 防火墙设置

    唯一需要注意的是当你的网站设置的端口不是默认的80的时候,需要在防火墙那里将你新设置的端口设置为allow 先要到云的后台设置  “入站安全规则”--> 将你的网站端口设置为Allow 1.通过 ...

  8. Django - 美化显示request.META

    def index(request): values = request.META.items() html = [] for k, v in values: html.append('<tr& ...

  9. iOS多线程编程的知识梳理

    多线程编程也称之为并发编程,由于其作用大,有比较多的理论知识,因此在面试中也是受到面试官的青睐.在日常项目开发中,至少网络请求上是需要使用到多线程知识的,虽然使用第三方的框架比如AFNetworkin ...

  10. java编译器不匹配问题(java compiler level does not match the version of the installed java project facet)

    问题:项目经常copy过来,经常会报说Java编译器不匹配 解决方法:找到项目所在的目录,在.settings子目录里面,用文本编辑器打开org.eclipse.wst.common.project. ...