java网络编程IO和NIO

本文深入探讨了网络编程的基本概念,将复杂的网络通信过程比作日常的电话沟通,形象地解释了服务端与多个客户端的交互原理。文章进一步剖析了传统IO模型在处理多客户端连接时的弊端,为读者理解后续NIO的引入提供了清晰的背景。

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

网络编程

网络编程指的是设备和设备之间的数据交换,狭义可以理解成计算机间的数据交换。类似两个人打电话,人等同于计算机角色,传递的信息类似数据交换,先拨号的可以算作客户端,被拨号的,也就等同于被连接的可以理解成服务端。在网络通信中,服务端是一个,但连接该服务端的客户端是多个,类比打电话,被打电话的人是服务端,可以被动接听很多人的电话,也就是可以被很多客户端连接。

IO实现网络通信

在java 1.4 NIO出现之前,我们一直使用Io实现。先理解一下它的实现方式。

原理图示意
javaIO通信方式
具体代码实现


IO实现的弊端
我们知道客户端是可以多个的,但是IO中服务端的accpet方法是一个堵塞方法,也就是尽管有很多和客户端,但是accpet方法会让这些客户端排长队,一个一个处理,即使是一个客户端他连接了服务端,但还没有准备好数据,他依然占用了这个连接并且占用到直到准备好数据,完成一次通信,才开始处理下一个。所以这样会浪费很多资源,因此就出现了NIO。

NIO简介

java代码演示

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值