C++ 状态机开发

1.状态机的基本概念

1.1 状态(State):表示系统当前的条件或环境。比如,在交通信号灯的例子中,状态可以是红灯、绿灯或黄灯。

1.2 事件(Event):表示某个外部或内部的动作,导致状态的改变。事件可以是定时器到期、传感器输入、用户操作等。

1.3 转换(Transition):从一个状态到另一个状态的过程。状态转换可以是由事件引起的,也可以是时间驱动的。

1.4 动作(Action):在状态转换时或在进入某个状态时执行的操作。这些操作可以是日志记录、状态初始化等。

2.状态机的设计

通常,状态机的设计分为以下几个步骤:

定义状态:通过枚举或常量定义状态。

实现状态机类:设计一个类来管理状态和状态转换逻辑。

定义事件和动作:处理状态转换的条件和触发的动作。

集成和测试:将状态机类应用到实际场景中,并测试其行为。

3.示例

3.1. 定义状态枚举

使用枚举来定义信号灯的三种状态:红灯、绿灯和黄灯。

复制代码
enum class TrafficLightState {
    RED,
    GREEN,
    YELLOW
};

3.2. 定义状态机类

创建一个类来管理信号灯的状态和状态转换逻辑。

复制代码
#include <iostream>
#include <string>

class TrafficLightStateMachine {
public:
    TrafficLightStateMachine() : currentState(TrafficLightState::RED) {}

    // 处理状态转换逻辑
    void handleEvent() {
        switch (currentState) {
            case TrafficLightState::RED:
                transitionToState(TrafficLightState::GREEN);
                break;
            case TrafficLightState::GREEN:
                transitionToState(TrafficLightState::YELLOW);
                break;
            case TrafficLightState::YELLOW:
                transitionToState(TrafficLightState::RED);
                break;
        }
    }

    TrafficLightState getCurrentState() const {
        return currentState;
    }

private:
    TrafficLightState currentState;

    void transitionToState(TrafficLightState newState) {
        // 执行状态转换时的动作
        std::cout << "Transitioning from " << getStateName(currentState) 
                  << " to " << getStateName(newState) << std::endl;
        currentState = newState;
    }

    std::string getStateName(TrafficLightState state) const {
        switch (state) {
            case TrafficLightState::RED: return "Red Light";
            case TrafficLightState::GREEN: return "Green Light";
            case TrafficLightState::YELLOW: return "Yellow Light";
            default: return "Unknown";
        }
    }
};

3.3. 使用状态机

在main函数中模拟交通信号灯的运行。

复制代码
#include <thread>
#include <chrono>

int main() {
    TrafficLightStateMachine trafficLight;

    for (int i = 0; i < 6; ++i) {
        trafficLight.handleEvent();
        std::this_thread::sleep_for(std::chrono::seconds(2)); // 模拟时间延迟
    }

    return 0;
}

4.其他高级状态机设计

带有条件判断的状态转换:状态转换可以基于更复杂的条件,而不仅仅是简单的事件触发。

带有子状态机的层次化状态机:状态机中的每个状态可以包含子状态机,这样可以将复杂的逻辑分解为更小的模块。

带有并行状态的状态机:可以设计状态机中的某些状态是并行执行的,即多个状态可以同时处于活动状态。

5.应用场景

通信协议处理:如 TCP/IP 协议栈中的各个协议层处理。

游戏开发:控制角色的状态(移动、攻击、死亡等)。

用户界面:基于用户输入的状态转换。

工业控制系统:在工业自动化中,状态机可以用来控制机器的运行状

6.总结

状态机是一种强大且灵活的设计模式,适用于多种场景。通过将复杂的逻辑分解为状态、事件和转换,可以使代码更加模块化、易于理解和维护。


推荐一个零声学院项目课,个人觉得老师讲得不错,分享给大家:
零声白金学习卡(含基础架构/高性能存储/golang云原生/音视频/Linux内核)
https://xxetb.xet.tech/s/3Zqhgt

相关推荐
coding随想27 分钟前
JavaScript中的BOM:Window对象全解析
开发语言·javascript·ecmascript
念九_ysl1 小时前
Java 使用 OpenHTMLToPDF + Batik 将含 SVG 遮罩的 HTML 转为 PDF 的完整实践
java·开发语言·pdf
yaoxin5211231 小时前
124. Java 泛型 - 有界类型参数
java·开发语言
liulilittle2 小时前
深度剖析:OPENPPP2 libtcpip 实现原理与架构设计
开发语言·网络·c++·tcp/ip·智能路由器·tcp·通信
88号技师2 小时前
2025年6月一区-田忌赛马优化算法Tianji’s horse racing optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
勤奋的知更鸟2 小时前
Java 编程之模板方法模式
java·开发语言·模板方法模式
十年编程老舅2 小时前
跨越十年的C++演进:C++20新特性全解析
c++·c++11·c++20·c++14·c++23·c++17·c++新特性
上单带刀不带妹3 小时前
手写 Vue 中虚拟 DOM 到真实 DOM 的完整过程
开发语言·前端·javascript·vue.js·前端框架
-凌凌漆-3 小时前
【Qt】QStringLiteral 介绍
开发语言·qt