用LOL获得BUFF场景来看待Guava之事件总线
时间:2022-07-23
本文章向大家介绍用LOL获得BUFF场景来看待Guava之事件总线,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
栗子
public class TestPreconditions {
static class Listener {
@Subscribe
public void listen(String eventData) {
System.out.println("接收到事件数据:" + eventData);
}
@Subscribe
public void listen(Integer eventData) {
System.out.println("接收到事件int数据:" + eventData);
}
}
public static void main(String[] args) {
EventBus bus = new EventBus();
bus.register(new Listener());
bus.post("这是事件数据!");
bus.post(123456);
}
}
结果:
应用场景
我们假设你需要设计一个lol里面各种英雄获得buff的处理,你就可以采用如下代码
public class TestLolBuff {
//蓝buff
static class BlueBuff {
}
//红buff
static class RedBuff {
}
//小龙buff
static class DragonetBuff {
}
//大龙buff
static class BaronBuff {
}
static class Listener {
@Subscribe
public void listen(BlueBuff eventData) {
System.out.println("我得到了蓝buff:");
}
@Subscribe
public void listen(RedBuff eventData) {
System.out.println("我得到了红buff:");
}
@Subscribe
public void listen(DragonetBuff eventData) {
System.out.println("我得到了小龙buff:");
}
@Subscribe
public void listen(BaronBuff eventData) {
System.out.println("我得到了大龙buff:");
}
}
public static void main(String[] args) {
EventBus bus = new EventBus();
bus.register(new Listener());
bus.post(new DragonetBuff());
}
}
输出:
异步
public static void main(String[] args) {
AsyncEventBus bus = new AsyncEventBus();
bus.register(new Listener());
bus.post(new DragonetBuff());
}
与Spring结合使用
每次都new AsyncEventBus();这种方式为免有点太low,可以使用@Bean
注解构建一个Bean对象
@Component
public class AsyncEventBusBean {
@Bean
public AsyncEventBus asyncEventBus() {
AsyncEventBus eventBus = new AsyncEventBus(Executors.newFixedThreadPool(10));
eventBus.register(new xxx());
return eventBus;
}
}
@Autowired
private AsyncEventBus asyncEventBus;
asyncEventBus.post(xxx);
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- [docker]安装Mysql
- [Centos7]linux运行django项目报错no module named _ssl
- [Centos7]在非标准端口上运行SSH
- [Centos7]安装及配置bind(DNS服务)
- [Centos7.2]关于crontab报错
- [Centos7.2]关于升级python后防火墙无法启动
- [Centos7]关于限制IP通过ssh登陆
- Apache安装SSL证证书
- 打卡群刷题总结0717——不同路径 II
- [Centos7.2]Django挂载后台运行
- [Centos7+python3]IPy模块安装
- KVM实现分布式部署lamp并安装WordPress
- NumPy学的还不错?来试试这20题!
- 打卡群刷题总结0718——最小路径和
- linux之iptables应用详解