要将服务端线程池创建改为 ThreadPoolExecutor 创建,您可以按照以下方式修改代码:
public class Server {
private static final int PORT = 12345;
private static final String SENSITIVE_WORD = "操";
private static List<Socket> clients = new ArrayList<>();
public static void main(String[] args) {
// 创建 ThreadPoolExecutor 对象
ThreadPoolExecutor pool = new ThreadPoolExecutor(
Runtime.getRuntime().availableProcessors(),
Runtime.getRuntime().availableProcessors(),
0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<>());
try (ServerSocket serverSocket = new ServerSocket(PORT)) {
System.out.println("服务器启动,等待客户端连接...");
while (true) {
Socket clientSocket = serverSocket.accept();
clients.add(clientSocket);
pool.execute(new ClientHandler(clientSocket));
}
} catch (IOException e) {
e.printStackTrace();
} finally {
pool.shutdown();
}
}
private static class ClientHandler implements Runnable {
// 省略其他代码...
@Override
public void run() {
// 省略其他代码...
}
// 省略其他方法...
}
}
通过上述修改,我们使用 ThreadPoolExecutor 创建了一个线程池对象,并设置了核心线程数和最大线程数为可用的处理器数量。此外,还设置了队列容量为无界队列 LinkedBlockingQueue。根据需要,您可以根据实际情况对线程池进行调整。
内容由零声教学AI助手提供,问题来源于学员提问




