Java简单状态机实现

状态机负责状态的扭转 比如我们平时在业务中可以简单实用
getState().next()进行状态扭转 代码如下,当然这只是简单的例子


public enum StateMachine {

    START {
        @Override
        StateMachine next() {
            return PROCESS;
        }
    }, PROCESS {
        @Override
        StateMachine next() {
            return END;
        }
    }, END() {
        @Override
        StateMachine next() {
            return END;
        }
    };

    abstract StateMachine next();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
有限状态机(Finite State Machine,FSM)是一种数学模型,用于描述自动化系统的行为。在Java中,可以使用类来实现有限状态机。 首先,需要定义一个状态枚举类,如下所示: ```java public enum State { STATE1, STATE2, STATE3 } ``` 然后,可以定义一个状态转移表,它描述了从一个状态到另一个状态的转移条件。例如: ```java public class TransitionTable { private static final Map<State, Map<String, State>> table = new HashMap<>(); static { // 从STATE1转移到STATE2,条件是输入的字符串为"abc" Map<String, State> transitionsFromState1 = new HashMap<>(); transitionsFromState1.put("abc", State.STATE2); table.put(State.STATE1, transitionsFromState1); // 从STATE2转移到STATE3,条件是输入的字符串为"def" Map<String, State> transitionsFromState2 = new HashMap<>(); transitionsFromState2.put("def", State.STATE3); table.put(State.STATE2, transitionsFromState2); // ... } public static State getNextState(State currentState, String input) { if (!table.containsKey(currentState)) { throw new IllegalArgumentException("Invalid state: " + currentState); } Map<String, State> transitions = table.get(currentState); if (!transitions.containsKey(input)) { throw new IllegalArgumentException("Invalid input: " + input); } return transitions.get(input); } } ``` 最后,可以编写一个状态机类,该类包含一个当前状态和一个输入方法,用于根据输入和状态转移表更新当前状态。例如: ```java public class StateMachine { private State currentState; public StateMachine(State initialState) { this.currentState = initialState; } public void input(String input) { currentState = TransitionTable.getNextState(currentState, input); } public State getCurrentState() { return currentState; } } ``` 可以使用以下代码来测试状态机: ```java StateMachine stateMachine = new StateMachine(State.STATE1); stateMachine.input("abc"); stateMachine.input("def"); System.out.println(stateMachine.getCurrentState()); // 输出STATE3 ``` 这是一个简单的有限状态机实现,可以根据需要进行扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值