Я написал простой динамический FSM. Dynamic
означает, что переход состояния является динамическим, а не статическим, как показано в ConcreteStateB
.Подробнее .net-подход для динамического конечного автомата
namespace FSM_Example
{
using System;
class Program
{
static void Main()
{
var context = new Context(new ConcreteStateA());
context.Run();
Console.Read();
}
}
abstract class State
{
public abstract void Execute(Context context);
}
class ConcreteStateA : State
{
public override void Execute(Context context)
{
context.State = new ConcreteStateB();
}
}
class ConcreteStateB : State
{
public override void Execute(Context context)
{
Console.Write("Input state: ");
string input = Console.ReadLine();
context.State = input == "e" ? null : new ConcreteStateA();
}
}
class Context
{
private State _state;
public Context(State state)
{
State = state;
}
public State State
{
get { return _state; }
set
{
_state = value;
Console.WriteLine("State: " + _state.GetType().Name);
}
}
public void Run()
{
while (_state != null)
{
_state.Execute(this);
}
}
}
}
Это реализует конечный автомат, как описано в GoF305
.
Поскольку я новичок в C# и .net: Есть ли более эффективные способы архивирования этой цели, используя более конкретные функции от .net
или C#
?