一、 实例

  1. 例子1
public class NettyServer {public static void main(String[] args) throws InterruptedException {EventLoopGroup parentGroup = new NioEventLoopGroup();EventLoopGroup childGroup = new NioEventLoopGroup();try {ServerBootstrap bootstrap = new ServerBootstrap();bootstrap.group(parentGroup, childGroup).channel(NioServerSocketChannel.class).childHandler(new ChannelInitializer<NioServerSocketChannel>() {@Overrideprotected void initChannel(NioServerSocketChannel ch) throws Exception {ChannelPipeline pipeline = ch.pipeline();//添加处理器pipeline.addLast(new StringDecoder());pipeline.addLast(new StringEncoder());}});//前面都是准备阶段,执行到bind这行的时候,原生nio代码里体现的init,register,bind Port才开始真正执行//这里也要进行阻塞sync():保证在初始化完成后才进行操作ChannelFuture future = bootstrap.bind(8888).sync();System.out.println("服务器已启动。。。");//同步阻塞等待future.channel().closeFuture().sync();} finally {parentGroup.shutdownGracefully();childGroup.shutdownGracefully();}}
}

在这里面future.channel().closeFuture().sync();这个语句的主要目的是,如果缺失上述代码,则main方法所在的线程,即主线程会在执行完bind().sync()方法后,会进入finally 代码块,之前的启动的nettyserver也会随之关闭掉,整个程序都结束了。该语句能让线程进入wait状态,也就是main线程暂时不会执行到finally里面,nettyserver也持续运行,如果监听到关闭事件,可以优雅的关闭通道和nettyserver,虽然这个例子中,永远不会监听到关闭事件(代码比较简洁,没有涉及触发关闭事件的代码)。该例子仅仅为了展示存在api shutdownGracefully,可以优雅的关闭nettyserver。当然,如果你在代码中通过其他线程触发了关闭事件,此时main会响应事件,并进入finally代码块,进行优雅的关闭操作。

如果我们不想加f.channel().closeFuture().sync()又想保证程序正常运行怎么办,简单,去掉finally 里面关闭nettyserver的语句即可。下面我们来改造下:

public class NettyServer {public static void main(String[] args) throws InterruptedException {EventLoopGroup parentGroup = new NioEventLoopGroup();EventLoopGroup childGroup = new NioEventLoopGroup();try {ServerBootstrap bootstrap = new ServerBootstrap();bootstrap.group(parentGroup, childGroup).channel(NioServerSocketChannel.class).childHandler(new ChannelInitializer<NioServerSocketChannel>() {@Overrideprotected void initChannel(NioServerSocketChannel ch) throws Exception {ChannelPipeline pipeline = ch.pipeline();//添加处理器pipeline.addLast(new StringDecoder());pipeline.addLast(new StringEncoder());}});//前面都是准备阶段,执行到bind这行的时候,原生nio代码里体现的init,register,bind Port才开始真正执行ChannelFuture future = bootstrap.bind(8888).sync();System.out.println("服务器已启动。。。");//同步阻塞等待//future.channel().closeFuture().sync();} finally {//            parentGroup.shutdownGracefully();
//            childGroup.shutdownGracefully();}}
}

是不是一目了然了?其实入门例子可以完全按照我的改造的方法来演示,去掉f.channel().closeFuture().sync()。否则,对于刚入门的小白来说,无法理解这个例子中的奥义。

  1. 深入研究

前文得知,future.channel().closeFuture().sync()作用是为了让netty不会关闭,那么具体是什么原理呢?

原因是这样:

netty为了基于性能,多采用异步方式,而我们通过调用sync()方法,会让主线程间接调用wait()方法,进而实现阻塞的效果。当然,在简单的demo中,会这样实现阻塞,但是在正式环境下,一般不会这么写。同样的,在前面“b.bind(port).sync();”中也有sync(),原理类似,当调用bind(port)时,是异步的,因此为了保证在初始化完成后才进行操作,避免调用一个初始化未完成的句柄,sync方法是等待异步操作执行完毕。

总结就是:sync()让主线程间接调用wait()方法

  1. 当然也可以使用监听器进行异步回调
public class ASychNettyServer {public static void main(String[] args) throws InterruptedException {EventLoopGroup parentGroup = new NioEventLoopGroup();EventLoopGroup childGroup = new NioEventLoopGroup();ServerBootstrap bootstrap = new ServerBootstrap();bootstrap.group(parentGroup, childGroup).channel(NioServerSocketChannel.class).childHandler(new ChannelInitializer<NioServerSocketChannel>() {@Overrideprotected void initChannel(NioServerSocketChannel ch) throws Exception {ChannelPipeline pipeline = ch.pipeline();//添加处理器pipeline.addLast(new StringDecoder());pipeline.addLast(new StringEncoder());}});//前面都是准备阶段,执行到bind这行的时候,原生nio代码里体现的init,register,bind Port才开始真正执行//这里也要进行阻塞sync():保证在初始化完成后才进行操作ChannelFuture future = bootstrap.bind(8888).sync();future.addListener((ChannelFutureListener) channelFuture -> {if(future.isSuccess()){System.out.println("8888端口绑定成功");System.out.println("服务器已启动。。。");}else {System.out.println("8888端口绑定失败");}});}
}

future.channel().closeFuture().sync()作用 bind(port).sync()作用相关推荐

  1. linux sync命令,Linux中sync命令起什么作用呢?

    摘要: 下文讲述Linux中sync的功能说明,如下所示: sync命令功能: 用于强制将改变的内容立刻写入磁盘 注意事项: 用户通常不用运行sync命令,系统会自动运行 update或bdflush ...

  2. 【Netty】Netty 核心组件 ( Future | Channel | Selector | ChannelHandler )

    文章目录 一. Future / ChannelFuture 异步操作监听组件 二. Channel 通道组件 三. Selector 选择器组件 四. ChannelHandler 通道处理器组件 ...

  3. 织梦channel标签currentstyle样式无效不起作用

    我们在用织梦系统制作网站时,经常会用到channel标签来调子栏目.但是,很多朋友会遇到这种情况在使用channel标签来调子栏目的时候,指定 "type=son typeid=x" ...

  4. php cannot bind port to socket,PHP基于socket实现客户端和服务端通讯功能

    本文主要介绍了PHP基于socket实现的简单客户端和服务端通讯功能,可实现服务端接收客户端发送的字符串进行翻转操作后返回客户端的功能,需要的朋友可以参考下 服务端: set_time_limit(0 ...

  5. currentstyle 织梦_织梦channel标签currentstyle样式无效不起作用

    我们在用织梦系统制作网站时,经常会用到channel标签来调子栏目.但是,很多朋友会遇到这种情况在使用channel标签来调子栏目的时候,指定 "type=son typeid=x" ...

  6. java抽象类有什么用_java中抽象类的作用是什么?抽象类作用的例子

    你知道java当中抽象类的作用是什么吗?有什么作用?下面和小编一起来详细的了解一下具体的作用,以及看看抽象类作用的例子吧! 一.java抽象类的作用 java抽象类的作用具体的可以分成以下的三点: 1 ...

  7. java关键字的作用_java关键字及其作用

    java关键字及其作用 java 关键字及其作用 一. 关键字总览:关键字 含义abstract 表明类或者成员方法具有抽象属性assert 用来进行程序调试boolean 基本数据类型之一,布尔类型 ...

  8. 逃避条件作用和回避条件作用,两者的区别是?|小白心理-312/347考研答疑

    逃避条件作用和回避条件作用,两者的区别是?|小白心理-312/347考研答疑 解析: 逃避条件作用和回避条件作用都属于负强化. 负强化:撤销厌恶刺激,使得行为增加 逃避条件作用:对于已经发生的厌恶刺激 ...

  9. Spring注解@NonNull作用 Spring注解@Nullable作用 Spring NonNull 注解作用 Spring Nullable注解作用

    Spring注解@NonNull作用 Spring注解@Nullable作用 Spring NonNull 注解作用 Spring Nullable注解作用 一.概述 在看Spring源码的时候,经常 ...

最新文章

  1. 屏幕广播系统_如何设计系统,而不是屏幕
  2. [渝粤教育] 莆田学院 电机与拖动基础(一) 参考 资料
  3. 10亿+文件数压测,阿里云JindoFS轻松应对
  4. oracle 设置 shmmax,安装ORACLE时在Linux上设置内核参数的含义
  5. c语言如何调用三个子程序,哪位师傅知道51单片机怎样编写子程序?C语言的。在主程序里调...
  6. 【English】20190313
  7. FastDFS的安装及上传下载(二)
  8. 践行快乐音乐教育 郎朗The ONE全球公益钢琴盛典传递音乐力量!
  9. java/php/net/python大学生就业管理系统设计
  10. 【Pytorch】解决使用BucketIterator.splits警告volatile was removed and now has no effect. Use `with torch.no_g
  11. aa44444444444
  12. 帆软报表列表_动态图表 - FineReport报表官网
  13. 给ecmall添加积分购物的功能
  14. TinyPng批量压缩图片
  15. 继电器模块的的使用方法、引脚说明、内部结构、接线说明(超通俗超详细看了就能给别人讲)
  16. O2O外卖网“开吃吧”投百万年流水过亿
  17. Qt --实现语音读文字功能
  18. C#:EXCEL版本与相应dll版本的对应关系
  19. STM32移植lvgl遇到的bug(坑)
  20. linux的crontab绝对路径咋填,RHCE培训视频Crontab详解(创想云教育)

热门文章

  1. 6993: Dominoes(纯bfs)
  2. 在.NET Core中三种实现“可插拔”AOP编程方式(附源码)
  3. bzoj2194 快速傅立叶之二
  4. [高级软件工程教学]团队Beta阶段成绩汇总
  5. 移动设备真机调试本地程序的Node.js【无需连wifi】
  6. LeetCode-Majority Element II
  7. 夺命雷公狗---微信开发26----客服消息接口基础和推送视频
  8. 转:用java调用oracle存储过程总结(比较好理解)
  9. 吴恩达 coursera ML 第八课总结+作业答案
  10. Python: adb自动化ce'shi