当前位置: 首页 > 知识库问答 >
问题:

重载是否违反Liskov替代原则?

牛昱
2023-03-14

我是OOP的新手。最近我读到了关于Liskov替换原理的文章。

在下面给出的代码中,Square类继承Give_区域。假设Square类与Square相关(比如有效性检查)。Give_Area给出正方形的面积(4个顶点位于圆的周长上)和圆的面积。所以,如果给我一个半径,我必须打印圆和正方形的面积(由放置在圆周长上的顶点组成)。为了得到圆的面积,我使用了一个参数。但在求平方面积时没有参数。因此,我在这里做了重载。

#include<iostream>
#include<cmath>
using namespace std;

class Give_Area
{
    public:
    double Radius;

    double Area(double pi)
    {
        return pi*Radius*Radius;
    }

    double Area()
    {
        double temp = sqrt(2.0)*Radius;
        return temp*temp;
    }
};

class Square : public Give_Area
{
    public:
    bool Validity()
    {
        //checking validity
    }
};

int main()
{
    Give_Area* area = new Square();
    area->Radius = 3.0;
    cout<< "Area of Circle: " << area->Area(3.14159) <<endl;
    cout<< "Area of Square: " << area->Area() <<endl;
    return 0;
}

我的问题是。。

Is this overloading violating Liskov Substitution Principle?

如果这段代码违反了,那么有人能给我一个重载的例子,它不会违反利斯科夫替代原则吗?

我谷歌了我的查询,但一无所获。:(

提前谢谢。

共有1个答案

巫马承德
2023-03-14

Liskov的替代原理是关于抽象的。想象一个类Shape和从Shape派生的两个类Square矩形。现在Shape有一个(虚拟)方法getArea()。你会期望它返回覆盖的区域(混凝土,实例!)形状,不管它实际上是什么类型。因此,如果您在一个Shape实例上调用getArea(),您不关心它是矩形、正方形还是您能想到的任何其他形状。

如果没有重载,甚至不需要像LSP这样的东西,也就是说,答案是否定的,重载和LSP并不矛盾。

另一方面,正如paxdiablo指出的,应用LSP取决于设计。就上面的例子而言,这意味着,也许出于某种原因,你真的在乎阉羊你有没有长方形。嗯,在这种情况下,LSP说你应该考虑你的设计。

我不得不承认,在这一点上,我真的不明白你的代码的目标是什么。有一个类Give_Area,它根据pi的值计算圆圈的面积。第二种方法计算半径为对角线的正方形?然后是Square类。如果有效性()返回false,这意味着什么?也许是退化的正方形?我的建议是:重新考虑你的设计。问问自己“我要处理的类和对象是什么?“我想做模型的真实世界物体是什么?”

如何违反LSP在维基百科演示(上面的链接)。我试着再举一个例子。假设你有一个类Car,带有一个方法Drive()。派生类(RacingCarVan,...)可以指定速度,加速等。当汽车驶入水中(深水、湖泊、大海)时,汽车会断裂,下一个车库被称为。现在,您派生了一个类两栖车辆。这个不会在水上断裂,车库将被称为没有用。你预料到了吗?也许是的。但是如果没有,根据进一步的上下文,我会考虑一个类车辆,它是Car的基础。它将有一个方法mobile()。和驱动()仍然属于汽车将调用移动(),并可能调用(再次;-))车库的情况下发生麻烦。等等。

 类似资料:
  • 来自维基百科, Liskov的行为子类型概念定义了对象的可替代性概念;也就是说,如果S是T的子类型,则程序中T类型的对象可以替换为S类型的对象,而不改变该程序的任何期望属性(例如正确性)。 假设以下类层次结构: 基本抽象类-。它有一个只读属性,在后继程序中被重写。 基类的继承者-,它重写并返回灰色。 Cat的继任者-,它覆盖并返回带条纹的。 然后我们声明一个方法,参数类型为(不是)。 向该方法发送

  • 有人能告诉我下面的例子是否违反了LSP吗? 我有一个例子: 和子类: 和主类: 在此示例中,子类添加名为 的新属性,并通过对其自己的属性 进行附加检查来覆盖方法。 在main方法中,我创建了2个对象。第一个是类型的对象,第二个是类型的对象。 当验证人员时,因为所有前提条件都是正确的,所以它是正确的,但是对于员工,它将抛出< code > IllegalArgumentException ,因为它与

  • 如果S是T的一个子类型,那么T类型的对象可以被S类型的对象替换。 子类有两种不同的行为(选中与未选中),在某些情况下,除非更改当前代码,否则无法用子类对象有效地替换基类用法,例如,如果编写如下代码: 这是违反吗?,为什么/为什么不?。 资料来源:http://www.oracle.com/technetwork/articles/entarch/effective-exceptions-09234

  • 问题内容: 我的情况与Code Complete中Steve McConnell 提到的情况非常相似。我唯一的问题是基于车辆,而三轮车恰好是根据法律,属于汽车。到目前为止,汽车只有四个轮子。无论如何,我的域都不必要地复杂,因此很容易遵循下面的cats示例。 对重写例程并且在派生例程中不执行任何操作的类要保持怀疑。这通常表明基类的设计存在错误。例如,假设您有一个Cat类和一个例程Scratch(),

  • 我正在阅读为什么Java中的数组协方差不好(为什么数组是协方差的,而泛型是不变的?)。如果是的子类型,则是的子类型。这是一个问题,因为这样的事情是可以做的: 这与“正确”实现的泛型不同。不是的子类型 我试图理解为什么它是坏的本质,并且刚刚读了关于LSP的文章。它有没有违反LSP?似乎没有明显的违规行为。