通过 netty 实现异步任务回调获取执行结果

目前java 8 之前的异步并发编程的API(callable、future、futuretask),都有一个共同的问题,就是要获取结果必须阻塞等待。netty提供了一种通过回调的方式获得结果的办法:

Future<TGroup> future = businessEG.submit(new Callable<TGroup>() {
            @Override
            public TGroup call() throws Exception {
                //从数据库查询
                TGroup group = groupService.getDBTGroupById(gid);
                targetGroupsHM.put(gid, group);
                return group;
            }
        });

        future.addListener(new GenericFutureListener<Future<? super TGroup>>() {
            @Override
            public void operationComplete(Future<? super TGroup> future) throws Exception {
                //处理返回的结果
                TGroup group = (TGroup) future.get();
                if (group == null) {
                    byteBuf.release();
                    return;
                }
                sendToSingleGroup(group, byteBuf);
            }
        });
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Netty是一个基于Java网络应用框架,它提供了一种高效、可扩展的方式来开发网络应用程序。在Netty中,回调函数是一种常见的处理方式,用于处理异步操作的结果。 在高并发场景下,合理的回调函数设计可以提高系统的性能和可伸缩性。以下是一些关于Netty高并发合理的回调函数的介绍: 1. ChannelFutureListener:ChannelFutureListener是一个回调接口,用于监听I/O操作的结果。通过添加ChannelFutureListener,可以在I/O操作完成后执行相应的逻辑。在高并发场景下,可以使用ChannelFutureListener来处理大量的并发请求,例如在写入操作完成后释放资源或发送响应。 2. Promise和Future:Promise和Future是Netty中用于处理异步操作的接口。Promise表示一个异步操作的结果,而Future表示一个异步操作的凭证。通过Promise和Future,可以实现更加灵活的回调函数设计,例如在多个异步操作完成后执行某个逻辑。 3. ChannelHandler:ChannelHandler是Netty中用于处理I/O事件的组件。通过实现自定义的ChannelHandler,可以在不同的事件发生时执行相应的回调函数。在高并发场景下,可以根据具体需求实现自定义的ChannelHandler来处理并发请求,例如进行请求分发、连接管理等。 4. EventLoop:EventLoop是Netty中用于处理事件的线程。每个Channel都会绑定一个EventLoop,用于处理该Channel上的事件。通过合理地使用EventLoop,可以实现高效的事件处理和回调函数执行。 总结起来,Netty提供了多种处理异步操作的回调函数机制,可以根据具体需求选择合适的方式来设计高并发的回调函数。合理的回调函数设计可以提高系统的性能和可伸缩性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值