더 풍부한 대체 원칙 (원자 클래스와 원래 부모 클래스가 집계, 구성 및 종속성을 통해 결합을 줄 이도록 기본 클래스를 추가하여 부모 클래스 메서드를 다시 작성하지 마십시오)

기본 개념:

  1. 리히터 대체 원칙은 1988 년 매사추세츠 공과 대학의 한 소녀가 제안했습니다.
  2. 상속 할 때 하위 클래스의 부모 클래스 메서드를 재정의하지 마십시오
     (예 : 클래스 A의 모든 메서드가 클래스 B에 의해 재정의됩니다. 그런 다음 상속하는 이유는 무엇입니까? 새 클래스 B를 직접 만듭니다).
  3. 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);
	}
}

 

추천

출처blog.csdn.net/qq_41813208/article/details/102982811