里氏替换原则
| 
                         里氏替换: 子类能够替换父类,出现在父类能够出现的任何地方,子类必须完全实现父类的方法。在类中调用其他类时务必要使用父类,如果不能使用父类,则说明类的设计已经违背了原则。覆盖或实现父类的方法时输入参数可以被放大。即子类可以重载父类的方法,但输入参数不比父类方法中的小,这样在子类代替父类的时候,调用的仍然是父类的方法。 里氏替换原则是针对继承而言的,如果继承是为了实现代码重用,也就是为了共享方法,那么共享的方法应该保持不变,不被子类重新定义。如果继承是为了多态那么,而多态的前提是子类覆盖父类的方法所以将父类定义为抽象类,抽象类不能够实例化对象也就不存在替换这一说。 
 ?“子类可以扩展父类的功能,但不能改变父类原有的功能!!!!”? 百度百科定义: 里氏替换原则中说,任何基类可以出现的地方,子类一定可以出现。 LSP是继承复用的基石,只有当衍生类可以替换掉基类,软件单位的功能不受到影响时,基类才能真正被复用,而衍生类也能够在基类的基础上增加新的行为 ? 
 代码共享,减少创建类的工作量 继承是入侵性的(只要继承,就必须拥有父类的所有属性与方法); class Shape {
  constructor() {
	this.ant=‘蚁群‘
  }
}
class Rectangle extends Shape {
  constructor() {
	super();
    this.ant=‘蚁后‘
	this.action=‘啥也不干‘
  }
  setactions(dance) {
     this.action=dance
  }
  getArea() {
    return this.ant + this.action;
  }
}
class Square extends Shape {
  constructor() {
	super();
    this.ant=‘蚁后‘
	this.action=‘啥也不干‘
  }
  setaction(high) {
    this.action = high;
  }
  getArea() {
    return this.ant + this.action;
  }
} 
function renderLargeShapes(shapes) {
  shapes.forEach((shape) => {
  console.log(shape)
    switch (shape.constructor.name) {
      case ‘Square‘:
        shape.setaction(‘跳高‘);
		break;
      case ‘Rectangle‘:
        shape.setactions(‘跳舞‘);
		break;
    }
    let area = shape.getArea();
	console.log(area)
  })
}
let shapes = [new Rectangle(),new Square()];
renderLargeShapes(shapes);
 
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!  | 
                  
