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();
        }
    }
相关推荐
曹牧7 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
爬山算法8 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
七夜zippoe8 小时前
CANN Runtime任务描述序列化与持久化源码深度解码
大数据·运维·服务器·cann
盟接之桥8 小时前
盟接之桥说制造:引流品 × 利润品,全球电商平台高效产品组合策略(供讨论)
大数据·linux·服务器·网络·人工智能·制造
kfyty7258 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎8 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄8 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
忆~遂愿8 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
小韩学长yyds8 小时前
Java序列化避坑指南:明确这4种场景,再也不盲目实现Serializable
java·序列化
仟濹8 小时前
【Java基础】多态 | 打卡day2
java·开发语言