44、装饰器与适配器模式:C++ 中的灵活设计实践

装饰器与适配器模式:C++ 中的灵活设计实践

1. 装饰器模式基础与注意事项

在实现装饰器时,要避免意外改变基类的行为。例如,下面这个 DebugDecorator 的实现就存在微妙的问题:

template <typename U> class DebugDecorator : public U {
    double attack() {
        cout << "Attack: " << U::attack() << endl;
        return U::attack();
    }
};

这里的问题在于,装饰后的对象除了预期的打印行为外,还隐藏了对基类 attack() 方法的两次调用,这可能导致打印值不准确,并且会取消一些一次性的攻击加成。

为了实现更可复用、通用的装饰器,我们可以利用 C++ 的模板机制。以下是一个使用可变参数模板、参数包和完美转发实现的通用调试装饰器:

// Example 07
template <typename Callable> class DebugDecorator {
    public:
    template <typename F>
    DebugDecorator(F&& f, const char* s) :
        c_(std::forward<F>(f)), 
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值