浅谈Java的Nio以及报Connection refused: no further information异常原因?

本文介绍了NIO(New IO)的基本概念,包括其提供的缓存支持和Selector选择器,用以实现非阻塞的高性能IO操作。文章还探讨了通过Channel和Selector管理大量连接的方法,并分析了ConnectionRefused: no further information异常的原因。

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

nio即new io,为原有的io提供缓存(buffer)支持,并加入了selector选择器来支持非阻塞的高伸缩性的io.

io都是阻塞的,即获取连接(read)开始必须等到读/写操作全部结束才会释放资源,我们有1000个io操作就需要1000个线程去维护,显然对系统压力太大,在如今高并发横行的时代,io性能更加捉襟见肘.

nio为我们提供了channel,selector,我们通过管道channel传输数据,而channel需要注册在selector(选择器)上,一个选择器可以管理1000个channel,所以可以通过一个线程就搞定,性能明显提升.

Connection refused: no further information异常:

       1.socketChannel.connect( new InetSocketAddress("localhost",port));端口号被占用

       2.在nio服务端的ServerSocketChannel.socket().bind(new InetSocketAddress(port));只传入端口号(我就是这个原因,后来加上

hostname又可以了,这块还得深入了解)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值