java线程实现服务器与客户端互发消息

线程实现服务器与客户端互发消息

如果不用多线程来实现服务器与客户端互发消息则当一方发完消息后另一方才可以发,如果用了线程,因为多个线程可以同时执行,只要把发送和接收两个方法放入线程中让他们同时执行就可以实现服务器与客户端互发消息不受限制了

SendThread:

java 复制代码
public class SendThread implements Runnable{
    DataOutputStream dataOutputStream;
    public SendThread(Socket socket) throws IOException {
        //把Socket传进方法,把要发送的内容送入Socket
        dataOutputStream= new DataOutputStream(socket.getOutputStream());
    }

    @Override
    public void run() {
        while(true){
            Scanner scanner=new Scanner(System.in);
            String s=scanner.next();
            try {
                dataOutputStream.writeUTF(s);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

ReceiveThread:

java 复制代码
public class ReceiveThread implements Runnable{
    DataInputStream dataInputStream;
    ReceiveThread(Socket socket) throws IOException {
        //把Socket传进方法,得到Socket中的数据
        dataInputStream=new DataInputStream(socket.getInputStream());
    }
    
    @Override
    public void run(){
        Thread thread=Thread.currentThread();
        while(true) {
            try {
                String s = dataInputStream.readUTF();
                if (thread.getName().equals("客户端")){
                    System.out.println("服务器说:"+s);
                }
                if (thread.getName().equals("服务器")){
                    System.out.println("客户端说:"+s);
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

Server:

java 复制代码
public static void main(String[] args) {
        try {
            ServerSocket serverSocket=new ServerSocket(7788);
            System.out.println("服务器启动成功");
            Socket socket=serverSocket.accept();
            System.out.println("有客户端连接到服务器");
            SendThread sendThread=new SendThread(socket);
            ReceiveThread receiveThread=new ReceiveThread(socket);
            Thread tse=new Thread(sendThread);
            Thread tre=new Thread(receiveThread,"服务器");
            tse.start();
            tre.start();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

Client:

java 复制代码
public static void main(String[] args) {
        try {
            Socket socket=new Socket("192.168.124.185",7788);
            SendThread sendThread=new SendThread(socket);
            ReceiveThread receiveThread=new ReceiveThread(socket);
            Thread tse=new Thread(sendThread);
            Thread tre=new Thread(receiveThread,"客户端");
            tse.start();
            tre.start();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
相关推荐
qq_452396231 小时前
第十五篇:《UI自动化中的稳定性优化:解决flaky tests的七种武器》
运维·ui·自动化
abcnull2 小时前
用javaparser做精准测试
java·ast·静态代码分析·精准测试·javaparser
j_xxx404_2 小时前
Linux:静态链接与动态链接深度解析
linux·运维·服务器·c++·人工智能
叶小鸡2 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
juniperhan2 小时前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
ID_180079054732 小时前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
c++之路3 小时前
C++23概述
java·c++·c++23
墨风如雪3 小时前
别被“高价建站”劝退了!我跑了多年的 WordPress 架构,一年只花 $25.7
服务器
Elastic 中国社区官方博客3 小时前
Elastic-caveman : 在不损失 Elastic 最佳效果的情况下,将 AI 响应 tokens 减少64%
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·全文检索