Event-Listerner事件监听模式

事件监听模式其实就是一种观察者模式,只是角度有点不同,在Java的JavaBean机制以及GUI中都使用了事件监听模式。在如今AJAX RIA客户端中,事件监听模式也成为一个主要的界面模式。

事件监听模式分同步和异步两种实现方式,JavaBean机制和GUI基本都是同步机制,事件监听异步模型,需要引入Event Queue。

事件监听同步模式分两个部分:Event Source和Event Listener:
Event Source:被监听者的事件集合,可能是方法,提供事件的注册加入和移除功能。类似被观察者的集合。
Event Listener:事件的监听者,当事件被触发,所有监听这个事件的监听者将被通知,然后执行自己的Action响应动作。

事件监听异步模式在Source和Listener之间引入event queue,
event queue是一个基于事件的publish-subscribe. 它一种松耦合方式提供不同模块和角色之间异步通讯。它比同步更加松耦合,这样,我们就把Source-Listener改成了publish-queue-subscribe方式。

事件监听模式使用在客户端RIA比较多,因为这里是用户输入的源头,是事件发生的源头。而且在目前WOA趋势下,事件监听模式不能只单独局限于RIA客户端这个范围,还需要把事件通过http形式传递到服务器端,也就是跨客户端和服务器的,事件必须和服务器的PUSH异步结合在一起。这是一种先进的架构设计。

基于Javascript的ZK 5 RIA已经实现了这种先进的事件监听模式,见:
http://docs.zkoss.org/wiki/ZK_5:_Chat_with_Event_Queue#Event_queues_and_server_push

如果将这种异步的事件模式和服务器的OSGI结合,那么在服务器端更新一个Jar模块,可以主动通知到客户端浏览器,
这对服务器端模块管理很有好处。
http://bundle-exception.blogspot.com/2009/07/zk-on-osgi-dynamic-asynchronous.html




严格来说:MVC模式是一种同步机制,MVC的Controller是Mediator模式,而Mediator模式的特点和缺点就是封装通讯,而Observer模式则是分离通讯。

实践证明:象Observer这种分离通讯的做法是符合可伸缩性要求的,而Mediator模式这种封装通讯是不可伸缩的。

所以,可以说MVC模式是不可伸缩的,所以,才有REST替代一说,也可以在MVC中引入事件模式。ZK5的设计就是这种基于MVC模式基础上的事件异步架构。

所以,现在只是使用一个MVC的Web框架已经远远不满足伸缩性要求。

说得不客气的话:现在所有的基于MVC框架,如Struts 2或Webwork JSF Wicket,如果不在其上引入异步事件框架,都是不合格的,都是落后的技术。



>干脆摒弃jsp/servlet和主流servlet容器,用mina封装通讯
这才是最灵活 最伸缩的好办法,也是我目前推崇的。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值