状态模式(State Pattern)是行为型设计模式之一,用于允许一个对象在其内部状态改变时改变其行为。状态模式可以有效避免在对象中使用大量的条件语句,通过将状态的逻辑转移到独立的状态类中,实现状态与行为的分离。
核心思想
将对象的状态抽象为单独的类,使得对象的行为随着其状态变化而发生变化。状态模式的主要目的是让状态切换更加灵活、清晰,且更易于维护。
组成
- Context(上下文)
持有当前状态的引用,并提供行为接口以供外部调用。上下文会将请求委托给当前状态对象处理。 - State(抽象状态类)
定义状态对应的行为接口,具体状态类需实现该接口。 - ConcreteState(具体状态类)
实现抽象状态类中的行为,每个类对应一个具体状态。
优缺点
- 优点
避免了大量的条件语句或分支逻辑。
易于扩展新状态,通过新增状态类而非修改已有代码实现开闭原则。
状态切换更加灵活,符合单一职责原则。 - 缺点
增加了系统复杂性,需要引入多个状态类。
可能会导致类的数量增多。
// 抽象状态类
public interface OrderState {
void handle();
}
// 具体状态类:待支付
public class PendingState implements OrderState {
@Override
public void handle() {
System.out.println("订单处于待支付状态。");
}
}
// 具体状态类:已支付
public class PaidState implements OrderState {
@Override
public void handle() {
System.out.println("订单处于已支付状态。");
}
}
// 具体状态类:已完成
public class CompletedState implements OrderState {
@Override
public void handle() {
System.out.println("订单已完成。");
}
}
// 上下文类
public class OrderContext {
private OrderState state;
// 设置状态
public void setState(OrderState state) {
this.state = state;
}
// 调用当前状态对应的行为
public void handle() {
if (state != null) {
state.handle();
}
}
}
// 测试
public class Main {
public static void main(String[] args) {
OrderContext context = new OrderContext();
// 设置为待支付状态
context.setState(new PendingState());
context.handle();
// 设置为已支付状态
context.setState(new PaidState());
context.handle();
// 设置为已完成状态
context.setState(new CompletedState());
context.handle();
}
}
适用场景
一个对象的行为随状态变化而变化时。
避免过多的条件分支逻辑。
状态数量较多且需要频繁切换时。
如果你对实现细节或设计场景有更多问题,随时告诉我!