浅谈Java之多线程处理TCP请求

一、基本介绍

在Java中,处理TCP请求通常涉及到服务器和客户端的概念。服务器监听某个端口,等待客户端的连接请求,而客户端则发起连接到服务器的请求。在多线程环境中,服务器可以同时处理多个客户端的请求。

二、简单示例

下面是一个简单的示例,展示如何使用Java的ServerSocketSocket类来创建一个多线程的TCP服务器。

1. 服务器端

服务器端使用ServerSocket来监听端口,每当有客户端连接时,它就创建一个新的线程来处理这个连接。

java 复制代码
import java.io.*;
import java.net.*;

public class TCPServer {
    public static void main(String[] args) throws IOException {
        int port = 12345; // 服务器监听的端口
        ServerSocket serverSocket = new ServerSocket(port);

        while (true) {
            Socket clientSocket = serverSocket.accept(); // 接受客户端连接
            new ClientHandler(clientSocket).start(); // 为每个客户端创建新线程
        }
    }
}

class ClientHandler extends Thread {
    private Socket clientSocket;

    public ClientHandler(Socket socket) {
        this.clientSocket = socket;
    }

    public void run() {
        try {
            BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));
            OutputStream out = clientSocket.getOutputStream();
            String inputLine;
            while ((inputLine = in.readLine()) != null) {
                System.out.println("Received: " + inputLine);
                out.write(("Echo: " + inputLine + "\n").getBytes());
            }
            clientSocket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

2. 客户端

客户端使用Socket来连接服务器,并发送消息。

java 复制代码
import java.io.*;
import java.net.*;

public class TCPClient {
    public static void main(String[] args) throws IOException {
        String hostName = "localhost";
        int portNumber = 12345;

        Socket socket = new Socket(hostName, portNumber);

        PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
        BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
        BufferedReader stdIn = new BufferedReader(new InputStreamReader(System.in));

        String userInput;
        System.out.println("Enter messages (leave empty line to quit):");
        while ((userInput = stdIn.readLine()) != null) {
            out.println(userInput);
            if (userInput.isEmpty()) {
                break;
            }
            String fromServer = in.readLine();
            System.out.println("Echo: " + fromServer);
        }

        out.close();
        in.close();
        socket.close();
    }
}

说明:

  1. 服务器端

    • 使用ServerSocket在指定端口上监听。
    • 每当有新的客户端连接,就创建一个新的ClientHandler线程来处理这个连接。
    • ClientHandler类继承自Thread,用于处理客户端的输入和输出。
  2. 客户端

    • 通过Socket连接到服务器。
    • 发送消息到服务器,并接收服务器的响应。

这个示例展示了如何使用Java进行基本的多线程TCP通信。你可以根据需要扩展这个示例,比如添加错误处理、支持更多的并发连接等。

相关推荐
3GPP仿真实验室13 小时前
【Matlab源码】6G候选波形:OFDM-IM 索引调制仿真平台
开发语言·matlab
计算机学姐14 小时前
基于SpringBoot的校园社团管理系统
java·vue.js·spring boot·后端·spring·信息可视化·推荐算法
Coder_Boy_14 小时前
基于SpringAI的在线考试系统-企业级教育考试系统核心架构(完善版)
开发语言·人工智能·spring boot·python·架构·领域驱动
java1234_小锋14 小时前
Java高频面试题:SpringBoot如何自定义Starter?
java·spring boot·面试
落霞的思绪14 小时前
Spring AI Alibaba 集成 Redis 向量数据库实现 RAG 与记忆功能
java·spring·rag·springai
键盘帽子14 小时前
长连接中异步任务的同步等待陷阱:一次主线程阻塞的排查与修复
java·websocket·java-ee·web
你刷碗14 小时前
基于S32K144 CESc生成随机数
android·java·数据库
2301_7657031414 小时前
C++中的代理模式变体
开发语言·c++·算法
咚为14 小时前
Rust tokio:Task ≠ Thread:Tokio 调度模型中的“假并发”与真实代价
开发语言·后端·rust
灰子学技术14 小时前
性能分析工具比较pprof、perf、valgrind、asan
java·开发语言