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();
        }
    }
相关推荐
码出钞能力21 分钟前
linux内核模块的查看
linux·运维·服务器
考虑考虑37 分钟前
JDK9中的dropWhile
java·后端·java ee
想躺平的咸鱼干1 小时前
Volatile解决指令重排和单例模式
java·开发语言·单例模式·线程·并发编程
星辰云-1 小时前
# Linux Centos系统硬盘分区扩容
linux·运维·centos·磁盘扩容
Hellc0071 小时前
Nginx 高级 CC 与 DDoS 防御策略指南
运维·nginx·ddos
hqxstudying1 小时前
java依赖注入方法
java·spring·log4j·ioc·依赖
feilieren1 小时前
Docker 安装 Elasticsearch 9
运维·elasticsearch·docker·es
·云扬·1 小时前
【Java源码阅读系列37】深度解读Java BufferedReader 源码
java·开发语言
Bug退退退1232 小时前
RabbitMQ 高级特性之重试机制
java·分布式·spring·rabbitmq
小皮侠2 小时前
nginx的使用
java·运维·服务器·前端·git·nginx·github