기본 개념:
- 리히터 대체 원칙은 1988 년 매사추세츠 공과 대학의 한 소녀가 제안했습니다.
- 상속 할 때 하위 클래스의 부모 클래스 메서드를 재정의하지 마십시오
(예 : 클래스 A의 모든 메서드가 클래스 B에 의해 재정의됩니다. 그런 다음 상속하는 이유는 무엇입니까? 새 클래스 B를 직접 만듭니다). - Richter 대체 원칙은 상속이 두 클래스의 결합을 향상시키고 적절한 상황에서 집계, 구성 및 종속성을 통해 문제를 해결 한다고 말합니다 .
Richter 교체로 수행 할 작업 :
기본 등급 증가, 결합 감소
예를 들면 :
public class Liskov { public static void main(String[] args) { A a = new A(); System.out.println("11-3=" + a.func1(11, 3)); System.out.println("1-8=" + a.func1(1, 8)); System.out.println("-----------------------"); B b = new B(); System.out.println("11-3=" + b.func1(11, 3));//这里本意是求出11-3 System.out.println("1-8=" + b.func1(1, 8));// 1-8 System.out.println("11+3+9=" + b.func2(11, 3)); } } // A类 class A { // 返回两个数的差 public int func1(int num1, int num2) { return num1 - num2; } }
여기서 fun1 메서드에주의하세요. 프로그래머 1이 실수로 메서드를 다시 부모로 지정했습니다. 이름이 동일하여 11-3 = 14,1-9 = 9가 될 수 있습니다.
// B类继承了A // 增加了一个新功能:完成两个数相加,然后和9求和 class B extends A { //这里,重写了A类的方法, 可能是无意识 public int func1(int a, int b) { return a + b; } public int func2(int a, int b) { return func1(a, b) + 9; } }
해결책:
public class Liskov { public static void main(String[] args) { // TODO Auto-generated method stub A a = new A(); System.out.println("11-3=" + a.func1(11, 3)); System.out.println("1-8=" + a.func1(1, 8)); System.out.println("-----------------------"); B b = new B(); //因为B类不再继承A类,因此调用者,不会再func1是求减法 //调用完成的功能就会很明确 System.out.println("11+3=" + b.func1(11, 3));//这里本意是求出11+3 System.out.println("1+8=" + b.func1(1, 8));// 1+8 System.out.println("11+3+9=" + b.func2(11, 3)); //使用组合仍然可以使用到A类相关方法 System.out.println("11-3=" + b.func3(11, 3));// 这里本意是求出11-3 } } //创建一个更加基础的基类 class Base { //把更加基础的方法和成员写到Base类 } // A类 class A extends Base { // 返回两个数的差 public int func1(int num1, int num2) { return num1 - num2; } } // B类继承了A // 增加了一个新功能:完成两个数相加,然后和9求和 class B extends Base { //如果B需要使用A类的方法,使用组合关系 private A a = new A(); //这里,重写了A类的方法, 可能是无意识 public int func1(int a, int b) { return a + b; } public int func2(int a, int b) { return func1(a, b) + 9; } //我们仍然想使用A的方法 public int func3(int a, int b) { return this.a.func1(a, b); } }