之前我们写的服务器Socket示例demo,都是只能接收单次请求,一般服务器肯定是需要持续提供服务的,我们可以对demo进行一些改造。
服务器Socket持续同步接收请求
为了让服务器Socket能够持续接收请求,我们可以利用while循环。
例如:
import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
public class ServerSocketTest {
public static void main(String[] args) throws Exception {
// TODO 服务端处理客户端连接请求
ServerSocket serverSocket = new ServerSocket(3333);
//while循环持续监听请求
while (true) {
try {
// 阻塞方法获取新的连接
Socket socket = serverSocket.accept();
try {
int len;
byte[] data = new byte[1024];
InputStream inputStream = socket.getInputStream();
// 按字节流方式读取数据
while ((len = inputStream.read(data)) != -1) {
System.out.println(new String(data, 0, len));
}
} catch (IOException e) {
e.printStackTrace();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
这样虽然可以让ServerSocket持续监听客户端请求,但是如果有一个请求耗时太久,就会阻塞后面其他的连接,效率太低。
这就是BIO通信模型,采用BIO通信模型的服务端,通常由一个独立的Acceptor线程负责监听客户端的连接。我们一般通过在while(true) 循环中服务端会调用accept()方法等待接收客户端的连接的方式监听请求,请求一旦接收到一个连接请求,就可以建立通信套接字在这个通信套接字上进行读写操作,此时不能再接收其