java - Netty的future.channel().closeFuture().sync();到底有什么用?
问题描述
我看到很多Netty的例子都在末尾加上了这句话:future.channel().closeFuture().sync();
比如:
public class TimeServer { private int count = 0; public void bind(int port) {try { EventLoopGroup bossGroup = new NioEventLoopGroup(); EventLoopGroup workGroup = new NioEventLoopGroup(); ServerBootstrap b = new ServerBootstrap(); // (2) b.group(bossGroup, workGroup).channel(NioServerSocketChannel.class) // (3) .childHandler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel arg0) throws Exception { arg0.pipeline().addLast(new LineBasedFrameDecoder(1024)); arg0.pipeline().addLast(new StringDecoder()); arg0.pipeline().addLast(new ChannelInboundHandlerAdapter() {@Overridepublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception { // ByteBuf buf = (ByteBuf) msg; // byte[] req = new // byte[buf.readableBytes()]; // buf.readBytes(req); // String body = new String(req, 'UTF-8'); System.out.println( 'The Time Server Received order:' + msg + '; the counter is:' + ++count); // String currentTime = 'QUERY TIME // ORDER'.equalsIgnoreCase(body) // ? new // Date(System.currentTimeMillis()).toString() // : 'BAD ORDER'; // // currentTime = currentTime + // System.getProperty('line.separator'); // ByteBuf resp = // Unpooled.copiedBuffer(currentTime.getBytes()); // ctx.writeAndFlush(resp);} });} }); ChannelFuture future = b.bind(port).sync(); System.out.println('Server start listen at ' + port); future.channel().closeFuture().sync();System.out.println('执行到这里 ' + port);} catch (InterruptedException e) { e.printStackTrace();} } public static void main(String[] args) {new TimeServer().bind(10000); }}
但是我看这行代码一直没有执行。请问这是怎么回事呢?
问题解答
回答1:不是没执行,是主线程到这里就 wait 子线程退出了,子线程才是真正监听和接受请求的。
相关文章:
1. dockerfile - 为什么docker容器启动不了?2. boot2docker无法启动3. css3 - css字体样式加填充色而不是背景色4. 新手学习vue和node.js的困惑5. nignx - docker内nginx 80端口被占用6. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””7. 为什么我的find里面不放id返回的nuLL,不是默认的第一条8. dockerfile - 我用docker build的时候出现下边问题 麻烦帮我看一下9. docker网络端口映射,没有方便点的操作方法么?10. 请问连接文件怎么写