Java中IO模型之BIO(同步阻塞模型)
BIO:同步阻塞模型
在JDK1.4之前,建立网络通信采用的BIO模型
需要现在服务器启动一个ServerSocket,然后客户端启动一个Socket来对服务端进行连接,默认的情况下服务端需要对每一个请求建立一个线程等待处理,客户端发送请求后,需要等待服务端是否有相应的线程来处理客户端的连接,如果没有线程则会一致等待或者拒绝请求,如果有的话,客户端会等待线程来处理客户端请求
在了解BIO模型之前先让我们回顾一下Socket通信流程

基于BIO的编程
通过网络通信模拟echo命令的实现
服务端编程:
ServerSocket ssocket = null;
try {
//创建ServerSocket实例
ssocket = new ServerSocket();
//绑定端口
ssocket.bind(new InetSocketAddress(9999));
System.out.println("服务端已经启动...");
//进行监听,等待客户端的连接
Socket socket = ssocket.accept();
System.out.println("客户端:"+socket.getRemoteSocketAddress()+"连接上");
//进行读写操作
BufferedReader reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
String msg = reader.readLine();
System.out.println("客户端:"+socket.getRemoteSocketAddress()+"发送消息:"+msg);
//回复客户端消息
OutputStream write = socket.getOutputStream();
write.write(("echo:"+msg+

Java中的BIO模型在JDK1.4前被广泛使用,它在服务端每接收到一个客户端连接时需要创建新线程进行处理,造成同步阻塞。BIO编程流程包括服务端的ServerSocket实例创建、绑定端口、监听客户端连接,以及客户端的Socket连接、读写操作。由于accept、read/write、connect方法可能导致阻塞,因此在高并发场景下,通常结合多线程处理多个客户端请求,但线程资源限制了其并发处理能力,这促使了NIO模型的出现。
&spm=1001.2101.3001.5002&articleId=107491169&d=1&t=3&u=abe35e9bb11c4db2a0301d618a33f2d4)
394

被折叠的 条评论
为什么被折叠?



