3.Java 网络编程TCP通讯线程池例子

在上篇例子中,存在缺陷如果有一个客户端没有处理完,则后续会进入阻塞状态,也就是说同一个Server端,只能同时给Client端服务,这篇使用线程池完善上篇的例子

TCP服务端

import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.concurrent.*;
import java.util.logging.Logger;

/**
 * TCP 服务双向连接线程池版本
 * @version 1.0
 * @author terry
 * @date 2021/12/17
 */
public class TcpServer implements Runnable{

    public static Logger logger = Logger.getGlobal();

    private Socket socket;

    TcpServer(Socket socket){
        this.socket = socket;
    }

    public static void main(String[] args) throws IOException {
        logger.info("服务开始监听。。。");
        ServerSocket server = new ServerSocket(5002);
        ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(2, 4, 1000, TimeUnit.MILLISECONDS, new SynchronousQueue<Runnable>(), Executors.defaultThreadFactory(), new ThreadPoolExecutor.AbortPolicy());
        while (true) {
            Socket accept = server.accept();
            threadPoolExecutor.execute(new TcpServer(accept));
        }
    }

    @Override
    public void run() {
        logger.info("客户端连接。。。");
        try (DataInputStream input = new DataInputStream(socket.getInputStream());
                DataOutputStream out = new DataOutputStream(socket.getOutputStream())) {
            String data = input.readUTF();
            out.writeUTF(" hello client ! ");
            logger.info("服务端接受的信息:" + data);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

TCP客户端

import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.Socket;
import java.util.logging.Logger;

/**
 * TCP 客户端双向连接
 * @version 1.0
 * @author terry
 * @date 2021/12/17
 */
public class TcpClient {

    public static Logger logger = Logger.getGlobal();

    public static void main(String[] args) throws IOException {
        logger.info("客户端启动。。。");
        Socket client = new Socket("localhost", 5002);

        DataOutputStream out = new DataOutputStream(client.getOutputStream());
        DataInputStream input = new DataInputStream(client.getInputStream());
        out.writeUTF("hello server!");
        out.flush();
        // 这段会阻塞
        String msg = input.readUTF();
        logger.info("客户端接受消息:" + msg);
        out.close();
        input.close();
        client.close();
    }
}

启动顺序 先启动TCP服务端 后启动TCP客户端

TCP 服务端打印:

十二月 18, 2021 11:39:02 上午 com.terry.demo3.TcpServer main
信息: 服务开始监听。。。
十二月 18, 2021 11:39:09 上午 com.terry.demo3.TcpServer run
信息: 客户端连接。。。
十二月 18, 2021 11:39:09 上午 com.terry.demo3.TcpServer run
信息: 服务端接受的信息:hello server!

TCP 客户端打印:

十二月 18, 2021 11:39:09 上午 com.terry.demo3.TcpClient main
信息: 客户端启动。。。
十二月 18, 2021 11:39:09 上午 com.terry.demo3.TcpClient main
信息: 客户端接受消息: hello client ! 
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

terrybg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值