java多线程(2)---基于ExecutorService的socket通信线程池

本文介绍了如何使用ExecutorService创建一个线程池来处理socket通信,避免了每个客户端连接创建新线程带来的资源消耗。通过限制线程数量和重用线程,提高了服务器处理客户端请求的效率。文章提供了服务器端线程池代码实现,包括业务逻辑和线程池服务,以及客户端代码。展示了如何在服务器端创建ServerSocket,然后利用ExecutorService的newFixedThreadPool方法创建线程池,处理客户端连接请求。
摘要由CSDN通过智能技术生成
了解线程池       
        socket通信,如果服务器端采用的实现方式是:一个客户端对应一个线程。那么,每个新线程都会消耗系统资源:创建一个线程会占用CPU周期,而且每个线程都会建立自己的数据结构(如,栈),也要消耗系统内存,另外,当一个线程阻塞时,JVM将保存其状态,选择另外一个线程运行,并在上下文转换(context switch)时恢复阻塞线程的状态。随着线程数的增加,线程将消耗越来越多的系统资源,这将最终导致系统花费更多的时间来处理上下文转换盒线程管理,更少的时间来对连接进行服务。在这种情况下,加入一个额外的线程实际上可能增加客户端总服务的时间。

       我们可以通过限制线程总数并重复使用线程来避免这个问题。
       我们让服务器在启动时创建一个由固定线程数量组成的线程池。当一个新的客户端连接请求传入服务器,它将交给线程池中的一个线程处理,它首先会尝试使用已有的线程,但如果有必要,它会创建一个新的线程来处理任务。该线程处理完这个客户端之后,又返回线程池,继续等待下一次请求。如果连接请求到达服务器时,线程池中所有的线程都已经被占用,它们则在一个队列中等待,直到有空闲的线程可用。

实现步骤 
      1、与一客户一线程服务器一样,线程池服务器首先创建一个ServerSocket实例。
      2、然后创建N个线程,每个线程反复循环,从(共享的)ServerSocket实例接收客户端连接。当多个线程同时调用一个ServerSocket实例的accept()方法时,它们都将阻塞等待,直到一个新的连接成功建立,然后系统选择一个线程,为建立起的连接提供服务,其他线程则继续阻塞等待。
      3、线程在完成对一个客户端的服务后,继续等待其他的连接请求,而不终止。如果在一个客户端连接被创建时,没有线程在accept()方法上阻塞(即所有的线程都在为其他连接服务&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值