• 暑期JAVA学习(41.2)TCP通信——同时接受多个客户端消息


    1、本节之前的通信是否可以同时与多个客户端通信,为什么?

    ●不可以的

    ●单线程每次只能处理一个客户端的Socket通信

    2、如何才可以让服务端可以处理多个客户端的通信需求?

    ●引入多线程。

    3、同时处理多个客户端消息流程

    在这里插入图片描述

    4、具体实现

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    /**
     目标:完成Socket网络编程入门案例的客户端开发,实现1发1收。
     */
    public class ClientDemo01 {
        public static void main(String[] args) {
            try {
                System.out.println("===客户端启动===");
                // 1、创建Socket通信管道请求有服务端的连接
                // public Socket(String host, int port)
                // 参数一:服务端的IP地址
                // 参数二:服务端的端口
                Socket socket = new Socket(InetAddress.getLocalHost(),9999);
    
                // 2、从socket通信管道中得到一个字节输出流 负责发送数据
                OutputStream os = socket.getOutputStream();
    
                // 3、把低级的字节流包装成打印流
                PrintStream ps = new PrintStream(os);
    
                Scanner sc = new Scanner(System.in);
                while (true) {
                    System.out.println("请说:");
                    String msg = sc.nextLine();
                    // 4、发送消息
                    ps.println(msg);
                    ps.flush();
                }
    
                // 关闭资源。注意哦,不用时才关,不要随便关
                // socket.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    /**
     目标:实现服务端可以同时处理多个客户端的消息。
     */
    public class ServerDemo2 {
        public static void main(String[] args) {
            try {
                System.out.println("===服务端启动成功===");
                // 1、注册端口
                ServerSocket serverSocket = new ServerSocket(9999);
                // a.定义一个死循环由主线程负责不断的接收客户端的Socket管道连接。
                while (true) {
                    // 2、每接收到一个客户端的Socket管道,交给一个独立的子线程负责读取消息
                    Socket socket = serverSocket.accept();
                    System.out.println(socket.getRemoteSocketAddress()+ "上线啦!");
                    // 3、开始创建独立线程处理socket
                    new ServerReaderThread(socket).start();
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    public class ServerReaderThread extends Thread{
        private Socket socket;
        public ServerReaderThread(Socket socket){
            this.socket = socket;
        }
        @Override
        public void run() {
            try {
                // 3、从socket通信管道中得到一个字节输入流
                InputStream is = socket.getInputStream();
                // 4、把字节输入流包装成缓冲字符输入流进行消息的接收
                BufferedReader br = new BufferedReader(new InputStreamReader(is));
                // 5、按照行读取消息
                String msg;
                while ((msg = br.readLine()) != null){
                    System.out.println(socket.getRemoteSocketAddress() + "说了: " + msg);
                }
            } catch (Exception e) {
                System.out.println(socket.getRemoteSocketAddress() + "下线啦!!!");
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    5、本次是如何实现服务端接收多个客户端的消息的?

    ●主线程定义了循环负责接收客户端Socket管道连接

    ●每接收到一个Socket通信管道后分配一个独立的线程负责处理它。

  • 相关阅读:
    【算法集训 | 暑期刷题营】7.27题---并查集
    【MATLAB】 LMD信号分解+FFT傅里叶频谱变换组合算法
    第6章-图
    音乐信息提取-1-音频表示
    JVM 中类加载的链接与初始化
    2022/7/28
    ubuntu18下安装coova-chilli
    C#S7.NET实现西门子PLCDB块数据采集的完整步骤
    【二十】分割Segmentation_Threshold——threhold()算子
    数据挖掘实践(金融风控):金融风控之贷款违约预测挑战赛(上篇)[xgboots/lightgbm/Catboost等模型]--模型融合:stacking、blending
  • 原文地址:https://blog.csdn.net/xjl243636988/article/details/126193747