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:"