由于是在本地测试,只编写服务器端(使用线程池),客户端连接用telnet模拟
package com.ws.bio;
import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
/**
* @author 王顺
* @description
* @date 2022/8/2
*/
public class BIOServer {
public static void main(String[] args) throws IOException {
//线程池机制
//1.创建一个线程池
//2.每次有客户端连接,就创建一个线程,与之通讯(单独写一个方法)
ExecutorService newCachedThreadPool = Executors.newCachedThreadPool();
//创建ServerSocket
ServerSocket serverSocket = new ServerSocket(6666);
System.out.println("服务器启动了");
while (true) {
//监听等待客户端连接
Socket accept = serverSocket.accept();
System.out.println("连接到一个客户端");
//创建一个线程与之通讯(单独写一个方法)
newCachedThreadPool.execute(new Runnable() {
@Override
public void run() {
handler(accept);
}
});
}
}
//编写一个handler方法,和客户端通讯
public static void handler(Socket socket) {
byte[] bytes = new byte[1024];
//通过socket获取输入流
try {
System.out.println("当前线程信息id:" + Thread.currentThread().getId() + ",线程名称name:" + Thread.currentThread().getName());
InputStream inputStream = socket.getInputStream();
while (true) {
//读到byte里面
int read = inputStream.read(bytes);
if (read != -1) {
System.out.println(new String(bytes, 0, read));
} else {
break;
}
}
} catch (IOException e) {
e.printStackTrace();
} finally {
System.out.println("关闭和client连接");
try {
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}