5. 彤哥说netty系列之Java NIO核心组件之Channel

本文介绍了Java NIO中的核心组件Channel,包括其与BIO中的流的区别,强调了Channel的双向读写能力和在多路复用IO中的作用。文章通过实例展示了FileChannel、DatagramChannel、SocketChannel和ServerSocketChannel的使用,并指出Channel常与Buffer配合进行数据传输。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

nio

你好,我是彤哥,本篇是netty系列的第五篇。

简介

上一章我们一起学习了如何使用Java原生NIO实现群聊系统,这章我们一起来看看Java NIO的核心组件之一——Channel。

思维转变

首先,我想说的最重要的一个点是,学习NIO思维一定要从BIO那种一个连接一个线程的模式转变成多个连接(Channel)共用一个线程来处理的这种思维。

nio

nio

1个Connection = 1个Socket = 1个Channel,这几个概念可以看作是等价的,都表示一个连接,只不过是用在不同的场景中。

如果单从阻塞/非阻塞的角度来看的话,IO可以分成两大类,一类是Blocking IO,一类是Non-blocking IO,像IO五种模型中的后四种其实都可以看作是非阻塞型IO,只是各自使用的手段不相同罢了。

在Java中,我们说的非阻塞IO或者说NIO(New IO)主要是指多路复用IO,底层可以使用select/pol

C:\Windows\system32\cmd.e:x + zation(InitDestroyAnnotationBeanPostProcessor.java:136) ...26 common frames omittedCaused by: java.net.BindException: Address already in use: bindsun.nio.ch.Net.bind(Native Method)atatsun.nio.ch.Net.bind(Net.java:433)at sun.nio.ch.Net.bind(Net.java:425)sun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:223)atat io .grpc.netty.shaded. io.netty.channel.socket.nio.NioServerSocketchannel.doBind(NioServerSocketchannel.java:13at io . grpc.netty.shaded.io.netty.channel.Abstractchannel$AbstractUnsafe.bind(Abstractchannel.java:551)at io .grpc.netty.shaded. io.netty.channel.DefaultchannelPipeline$HeadContext.bind(DefaultchannelPipeline.java:134at io .grpc.netty.shaded.io.netty.channel.AbstractchannelHandlerContext.invokeBind(AbstractChannelHandlerContextat io.grpc.netty.shaded.io.netty.channel.AbstractchannelHandlerContext.bind(AbstractchannelHandlerContext.java:4at io.grpc .netty.shaded.io.netty.channel.Defaultchannelpipeline.bind(DefaultchannelPipeline.java:985)atio.grpc.nettyshaded.io.netty.channel.AbstractChannel.bind(Abstractchannel.java:247)atio.grpc.netty.shaded.io.netty..bootstrap.AbstractBootstrap$2.run(AbstractBootstrap.java:344)at io.grpc.netty.shaded, io.netty.util,concurrent.AbstractEventExecutor,safeExecute(AbstractEventExecutor.java:16 2) 0 java:503) 88) at io .grpc.netty,shaded. io.netty.util.concurrent .singleThreadEventExecutor.runAllTasks(SingleThreadEventExecutorio.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:518)io.grpc.netty..shaded.at io.grpc.netty.shaded. io.netty.util.concurrent ,singleThreadEventExecutor$6.run(SingleThreadEventExecutor .javaat io.grpc.netty.shaded.io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)at io.grpc.netty.shaded. io.netty.util.concurrent .FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)at java.lang.Thread.run(Thread.iava:748) at java:510) 1044)
最新发布
03-11
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值