当我们在开发复杂的网络应用的时候往往需要一个状态的设计,下面就以官网的一个收录机播放为例来说明:
收录机状态之间的转换我们应该不难理解:首先是空状态,就是什么磁带就没放进去然后是有磁带的状态,这两个状态之间的转换就是通过eject方法和load方法来交互的,
loaded表示已经有磁带了,那么我们发出play指令,这时候收录机就会播放磁带,这就是一个新状态playing,当我们点击stop时,状态又从playing转换为loaded了,当状态为playing的时候,点击pause按钮就会停止播放,再点击播放按钮就会继续播放,所以总结起来就是4种状态:Empty、Loaded、Playing、Paused,5个方法:eject,loaded,stop,play、pause。
下面我们在一个接口中定义这几个方法:
public interface TapeDeck {
void load(String nameOfTape);
void eject();
void play();
void pause();
void stop();
}
然后用字符串常量定义这几种状态,并且用注解将方法、状态和会执行的方法进行关联:
public class TapeDeckHandler {
//定义状态常量
@State public static final String EMPTY = "Empty";
@State public static final String LOADED = "Loaded";
@State public static final String PLAYING = "Playing";
@State public static final String PAUSED = "Paused";
//当执行load方法 从empty状态转换到loaded状态时执行的方法
@Transition(on = "load", in = EMPTY, next = LOADED)
public void loadTape(String nameOfTape) {
System.out.println("Tape '" + nameOfTape + "' loaded");
}
@Transitions({
@Transition(on = "play", in = LOADED, next = PLAYING),
@Transition(on = "play", in = PAUSED, next = PLAYING)
})
public void playTape() {
System.out.println("Playing tape");
}
@Transition(on = "pause", in = PLAYING, next = PAUSED)
public void pauseTape() {
System.out.println("Tape paused");
}
@Transition(on = "stop", in = PLAYING, next = LOADED)
public void stopTape() {
System.out.println("Tape stopped");
}
@Transition(on = "eject", in = LOADED, next = EMPTY)
public void ejectTape() {
System.out.println("Tape ejected");
}
}
我们看这段代码:
@Transition(on = "load", in = EMPTY, next = LOADED)
public void loadTape(String nameOfTape)
它的意思就是说当收录机从Empty状态,执行了load方法时loadtype方法将会被调用,然后收录机的状态会变为loaded。
下面是测试代码:
public static void main(String[] args) {
TapeDeckHandler handler = new TapeDeckHandler();//自定义的状态和方法
StateMachine sm = StateMachineFactory.getInstance(Transition.class).
create(TapeDeckHandler.EMPTY, handler);//用工厂方法基于
Transition注解创建一个状态机,初始状态为Empty,处理方法基于自定义的类
TapeDeck deck = new StateMachineProxyBuilder().create(TapeDeck.class, sm); //创建一个状态机代理对象,代理上一步产生的状态机 deck.load("The Knife - Silent Shout"); deck.play(); deck.pause(); deck.play(); deck.stop(); deck.eject();}
运行结果如下:
Tape 'The Knife - Silent Shout' loaded
Playing tape
Tape paused
Playing tape
Tape stopped
Tape ejected
分享到:
相关推荐
apache-mina-2.0.7-bin.tar,apache-mina-2.0.7-src.tar,rxtx-2.0-7pre1-i386-pc-mingw32,rxtx-2.1-7r2
apache-mina-2.0.16-bin.zip;apache-mina-2.0.16.zip
apache-mina-2.0.4-src
Apache MINA是 Apache 组织一个较新的项目,它为开发高性能和高可用性的网络应用程序提供了非常便利的框架。 当前发行的 MINA 版本支持基于 Java NIO 技术的 TCP/UDP 应用程序开发、串口通讯程序(只在最新的预览版...
mina-core-2.0.0-M6.jar mina-example-2.0.0-M6.jar mina-filter-codec-netty-2.0.0-M6.jar ...mina-statemachine-2.0.0-M6.jar mina-transport-apr-2.0.0-M6.jar mina-transport-serial-2.0.0-M6.jar
关于apache组织的mina通信框架,可替代 java.NIO.Selector 的更好选择, 里面包括 mina 2.07版本的源码,编译好的jar文件,以及一些网络上找来的网摘资料文档 [截至2013年10月止]。 打包文件名:...
mina-core-2.0.0-RC1.jar,mina-filter-compression-2.0.0-RC1.jar,mina-transport-apr-2.0.0-RC1.jar
apache-mina-2.0.16.zip
mina-filter-compression-2.0.7.jar,mina 过滤器jar包,核心包之一
米娜 apache-mina-2.0.16-bin.zip米娜 apache-mina-2.0.16-bin.zip米娜 apache-mina-2.0.16-bin.zip米娜 apache-mina-2.0.16-bin.zip
apache-mina-2.0.4-bin
apache-mina-2.0.7-bin.zip,apache-mina-2.0.7-src.zip,log4j-1.2.17.zip,slf4j-api-1.6.6.jar,slf4j-api-1.6.6-sources.jar,slf4j-log4j12-1.6.6.jar,mina-example-2.0.7.jar,mina-example-2.0.7-sources....
apache-mina-2.0.2-bin.tar.gz mina-core-2.0.2.jar
Apache Mina中文参考手册 Apache MINA是一个网络应用程序框架,用来帮助用户简单地开发高性能和高可靠性的网络应用程序
mina-core-2.0.1.jar,apache-mina-2.0.1
apache-mina-2.0.21-src.zip代码代码代码,
apache-mina-2.0.4 架包 源码 学习教程.apache mina是Apache 组织一个较新的项目,它为开发高性能和高可用性的网络应用程序提供了非常便利的框架。当前发行的 MINA 版本支持基于 Java NIO 技术的 TCP/UDP 应用程序...
使用-Apache-MINA-2-开发网络应用
mina-core-2.0.0-M1.jar/mina-example-1.0.5.jar/slf4j-jdk14-1.6.1.jar/slf4j-log4j12-1.6.1.jar mina 所用jar
mina2.0.7版本的源代码,官方发布的稳定版本