装饰器模式通过继承统一接口、组合实现功能扩展,如LoggingDecorator和CachingDecorator继承Decorator并包装Component,形成多层装饰链,运行时动态叠加行为,相比继承更灵活。

装饰器模式在C++中常用于动态地为对象添加功能,而继承是实现类间共性复用的基础机制。将两者结合使用,可以在保持代码灵活性的同时,充分利用已有类的结构和行为。
装饰器模式通过组合而非继承来扩展对象功能。核心是定义一个与被装饰对象共同基类的接口,让装饰器持有指向该基类的指针,从而在运行时叠加行为。
典型实现包含以下部分:
为了使装饰器能透明地替代原始对象,必须通过继承建立统一接口。这使得所有装饰器和被装饰对象可以被同等对待。
立即学习“C++免费学习笔记(深入)”;
例如:
class Component {
public:
virtual ~Component() = default;
virtual void operation() = 0;
};
<p>class ConcreteComponent : public Component {
public:
void operation() override {
std::cout << "Basic operation\n";
}
};</p><p>class Decorator : public Component {
protected:
Component<em> component_;
public:
explicit Decorator(Component</em> c) : component<em>(c) {}
virtual void operation() override {
component</em>->operation();
}
};</p>这里,Decorator 继承自 Component,并包含一个 Component* 成员。这种“继承+组合”的方式是装饰器模式的关键特征。
当需要多个装饰功能叠加时,可通过继承创建不同的具体装饰器,并逐层包装。
比如添加日志和缓存功能:
class LoggingDecorator : public Decorator {
public:
using Decorator::Decorator;
void operation() override {
std::cout << "[Log] Before operation\n";
Decorator::operation();
std::cout << "[Log] After operation\n";
}
};
<p>class CachingDecorator : public Decorator {
bool cached<em>{false};
public:
using Decorator::Decorator;
void operation() override {
if (!cached</em>) {
std::cout << "[Cache] First time running\n";
Decorator::operation();
cached_ = true;
} else {
std::cout << "[Cache] Skipped, already run\n";
}
}
};</p>使用时可嵌套包装:
auto comp = new ConcreteComponent();
Component* decorated = new LoggingDecorator(
new CachingDecorator(comp));
<p>decorated->operation(); // 先日志,再缓存判断,最后执行
decorated->operation(); // 日志仍输出,但缓存生效</p>结合继承与装饰器时需注意几点:
基本上就这些。装饰器模式借助继承实现接口统一,再通过组合达成灵活扩展,是一种比单纯继承更轻量且可动态调整的设计方案。
以上就是C++装饰器模式与继承关系结合使用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号