gpt4 book ai didi

java - 使用装饰器模式时找到特定类型的装饰器?

转载 作者:行者123 更新时间:2023-12-02 11:18:34 27 4
gpt4 key购买 nike

我正在构建一个需要使用多种类型的类似传感器的应用程序。由于传感器也可能有不同的行为或行为组合,因此我决定使用 decorator pattern

简而言之,我有一个如下所示的层次结构:

enter image description here

因此,任何具体的 ISensorDecorator 类都可以装饰(包装)任何具体的 IMeasureSensor 类,但由于具体的 ISensorDecorator 也是一个具体的IMeasureSensor,它们可以相互包装。例如

IMeasureSensor sensor = new FilteredSensorDecorator(
new CalibratedSensorDecorator(
new AccelerometerSensor()
)
);

是声明经过过滤和校准的加速度计传感器的有效语句。

现在假设我在 CaliberatedSensorDecorator 中有一个名为 setCalibration() 的方法。显然我不能打电话

sensor.setCalibration();

因为 IMeasureSensor 没有 setCalibration() 方法。并尝试使用

((CalibratedSensorDecorator)sensor).setCalibration()

也不起作用,因为 sensor 是一个 FilteredSensorDecorator

在这种特殊情况下,我如何才能到达CalibrateSensorDecorator,更一般地说,如何到达任何装饰器“链”中的任何特定装饰器?我不想将它们存储为单独的变量,我想动态地执行它。

最佳答案

由于这是一个设计问题,因此不会有任何正确答案,您需要做出选择,可能好,也可能不好。

您不应该为特定类添加方法,因为它将违反里氏替换原则

Objects in a program should be replaceable with instances of their subtypes without altering the correctness of that program.

您可以在构造函数CaliberatedSensorDecorator中初始化calibration,并在执行所需函数时使用它。

如果这不满足您的要求,则可能是 CaliberatedSensorDecorator 不属于您的传感器层次结构。考虑将其分离并使用策略模式来决定使用哪一个。

编辑1:

what I understand it doesn't say that you shouldn't add methods to subtypes?

是的,你说得对。它并不禁止添加方法,但如果这些方法正在改变对象的状态,那么应该重新考虑。所有这些模式只是指导方针,可以根据我们的需要进行调整。

解释我的理由:

假设您已在 CaliberatedSensorDecorator 上创建了 setCalibration()。您可以通过以下方式向内部开发人员或外部开发人员公开CaliberatedSensorDecorator。您已经创建了一个仅返回 IMeasureSensor 的工厂,如下所示:

public IMeasureSensor getCalibratedSensor(){
...
}

现在,您的 API 的用户只需了解这一点,并很高兴他/她当前的代码正在运行。但意识到他/她错过了经过数小时的调试后发现的setCalibration()。此外,他/她必须编写类型检查和类型转换代码才能使用此功能,这对于干净的代码来说可能不太好。

您应该尽量保持类的不可变性,以便调试和维护。重新创建对象没有什么坏处,因为较旧的对象将被垃圾收集。

这只是我的建议,您需要仔细考虑什么最适合您的用例。如果是强制性的,您仍然可以继续使用新方法来创建该方法,并确保已制作适当的文档以使用户了解其用法。

关于java - 使用装饰器模式时找到特定类型的装饰器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50087410/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com