用Rust实现23种设计模式之 策略模式

关注我,学习Rust不迷路!!

优点

  • 灵活性:策略模式允许你在运行时动态地选择不同的算法或行为,而无需修改已有的代码。
  • 可扩展性:通过添加新的策略类,你可以轻松地扩展策略模式的功能。
  • 可维护性:策略模式将不同的算法或行为封装在各自的策略类中,使代码更易于理解、维护和测试。

使用场景

  • 当有多个相关的类,它们之间的区别仅在于它们的行为或算法时,策略模式非常有用。
  • 当你需要在运行时动态地选择不同的算法或行为时,策略模式可以提供一种简单而灵活的解决方案。

代码示例

下面是一个简单的例子,演示如何使用 Rust 实现策略模式。

// 策略 trait
trait Strategy {
    fn execute(&self);
}
 // 具体策略类 A
struct ConcreteStrategyA;
 impl Strategy for ConcreteStrategyA {
    fn execute(&self) {
        println!("Executing strategy A");
    }
}
 // 具体策略类 B
struct ConcreteStrategyB;
 impl Strategy for ConcreteStrategyB {
    fn execute(&self) {
        println!("Executing strategy B");
    }
}
 // 环境类
struct Context {
    strategy: Box<dyn Strategy>,
}
 impl Context {
    fn new(strategy: Box<dyn Strategy>) -> Self {
        Context { strategy }
    }
     fn set_strategy(&mut self, strategy: Box<dyn Strategy>) {
        self.strategy = strategy;
    }
     fn execute_strategy(&self) {
        self.strategy.execute();
    }
}
 // 使用示例
fn main() {
    let strategy_a = Box::new(ConcreteStrategyA);
    let strategy_b = Box::new(ConcreteStrategyB);
     let mut context = Context::new(strategy_a);
    context.execute_strategy();
     context.set_strategy(strategy_b);
    context.execute_strategy();
}
  • 首先,我们定义了一个 Strategy trait,它包含一个 execute 方法,用于执行具体的策略。
  • 然后,我们实现了两个具体的策略类: ConcreteStrategyAConcreteStrategyB ,它们分别实现了 Strategy trait 的 execute 方法。
  • Context 结构体表示环境类,包含一个策略对象,并提供了设置策略和执行策略的方法。
  • main 函数中,我们创建了两个具体的策略对象,并使用 Context 类来执行不同的策略。

关注我,学习Rust不迷路!!

你可能感兴趣的:(当Rust邂逅GOF,rust,rust,设计模式,策略模式)