11、桥梁模式(Bridge)

桥梁模式的模型:


                                      火车                            产品A
   商人           赚钱                          桥梁          产品B           产品属性
                                      卡车                            产品C




                                                               Train                                           Product_A
Businessman    MakeMoney                                  Bridge                  Product_B       IProduct
                                                               Truck                                          Product_C


说明:使用桥梁模式来实现一下内容:
    一个商人做三种产品的生意,他有以下集中方式来运作:
    用火车来运输A产品赚钱,需要经过桥梁Bridge
    用卡车来运输A产品或者B产品或者C产品来赚钱,也需要经过桥梁Bridge


分析:A产品、B产品、C产品都具有产品属性IProduct
     桥梁Bridge可以通过产品属性为IProduct的产品
     火车与桥梁配合用产品A来赚钱(假设火车只允许运输A产品)
     卡车与桥梁配合用任意一种产品来赚钱(假定卡车可以运输任何产品)




int main()
{
        //第一种方式Train,只做Product_A生意:即参数只可以是Product_A
Product_A mProduct_A;         //定义产品A
Train mTrain(&mProduct_A);    //用产品A来初始化(设定)运输工具和桥梁
mTrain.MakeMoney();           //开动赚钱流程
cout << endl;


        //第二种方式Truck,可以做Product_A、Product_B、Product_C三种产品的任意一种,即参数可以是任何一种产品
Product_A mProduct_A1;          //定义产品A
Truck mTruck(&mProduct_A1);    //用产品A来初始化(设定)运输工具和桥梁
mTruck.MakeMoney();           //开动赚钱流程
cout << endl;


Product_B mProduct_B;          //定义产品B
Truck mTruck1(&mProduct_B);    //用产品B来初始化(设定)运输工具和桥梁
mTruck1.MakeMoney();           //开动赚钱流程
cout << endl;


Product_C mProduct_C;          //定义产品C
Truck mTruck2(&mProduct_C);    //用产品C来初始化(设定)运输工具和桥梁
mTruck2.MakeMoney();           //开动赚钱流程


return 0;
}
桥梁的定义:(让其可以操作具有IProduct属性的任何产品)
class Bridge
{
public:
Bridge(IProduct *pproduct);
virtual ~Bridge(void);
void MakeMoney();
private:
IProduct *m_pProduct;
};
桥梁模式Bridge)是一种结构型设计模式,它将抽象部分与实现部分分离,使它们可以独立地变化。它通过将抽象类与实现类分开来解耦,从而可以在两者之间建立一个桥梁桥梁模式适用于以下情况: - 当你希望在运行时切换或扩展抽象部分和实现部分时。 - 当你想要避免在抽象部分中使用继承的情况。 在桥梁模式中,抽象部分(Abstraction)定义了抽象类,并且包含了对实现部分(Implementor)的引用。抽象类提供了一组方法或功能,可以通过委派给实现部分来执行。实现部分定义了一组方法,通过这些方法可以实现抽象类中定义的功能。 以下是一个简单的示例来说明桥梁模式的用法: ```java // 实现部分接口 interface Implementor { void operationImpl(); } // 具体实现类A class ConcreteImplementorA implements Implementor { public void operationImpl() { System.out.println("ConcreteImplementorA: operationImpl"); } } // 具体实现类B class ConcreteImplementorB implements Implementor { public void operationImpl() { System.out.println("ConcreteImplementorB: operationImpl"); } } // 抽象类 abstract class Abstraction { protected Implementor implementor; public Abstraction(Implementor implementor) { this.implementor = implementor; } public abstract void operation(); } // 扩展抽象类 class RefinedAbstraction extends Abstraction { public RefinedAbstraction(Implementor implementor) { super(implementor); } public void operation() { System.out.println("RefinedAbstraction: operation"); implementor.operationImpl(); } } public class BridgeExample { public static void main(String[] args) { Implementor implementorA = new ConcreteImplementorA(); Implementor implementorB = new ConcreteImplementorB(); Abstraction abstractionA = new RefinedAbstraction(implementorA); abstractionA.operation(); Abstraction abstractionB = new RefinedAbstraction(implementorB); abstractionB.operation(); } } ``` 输出结果: ``` RefinedAbstraction: operation ConcreteImplementorA: operationImpl RefinedAbstraction: operation ConcreteImplementorB: operationImpl ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值