-
Socket通信的一般过程:
完整示例代码,请点击下载
服务端:
- 服务端在特定端口启动监听,这里需要注意有的电脑有多个网卡,我们可以绑定特定的网卡IP进行监听,也可以不绑定特定IP,这时就表示在所有网卡进行监听;
- 监听接受到有客户端连接,则对此连接进行处理,一般会将此连接交由一个客户端连接管理程序来管理,以便监听线程可以继续接受其他客户端,避免监听接受线程阻塞;
- 客户端连接管理程序一般会处理两件事情,一个是建立一个消息接收线程来接收此连接上传回的消息,接收到消息以后,还需要消息处理线程进行业务消息处理;一个是提供一个发送信息的函数用于通过此连接给客户端发送信息;
涉及到的线程总结:
服务端主线程:创建服务监听线程
服务监听线程:接受客户端连接并在接受到连接后对客户端连接进行管理
客户端消息接收线程:接收客户端发送过来的消息,并创建线程来处理此消息
业务处理线程:根据不同的业务消息处理不同的业务
心跳消息处理线程
客户端:
- 连接服务端,连接成功后在客户端连接上循环接收服务端的消息;
- 接收到服务端的消息以后,需要消息处理线程进行业务消息处理;
- 提供一个发送信息的函数用于通过此连接给服务端发送信息;
涉及到的线程总结:
客户端主线程:创建与服务端的连接线程
服务连接线程:连接服务端,并循环接收服务端的消息
业务处理线程:根据不同的业务消息处理不同的业务
心跳消息处理线程
-
Socket通信实例
通过构建服务端和客户端来展示Socket通信程序的一般实现框架,本程序使用了最基本的Socket及连接池、线程及线程池等,程序简单易理解,适合Java基础学习的同学学习参考,如果读者需要在自己的业务中使用此框架进行Socket相关的开发,也可以基于此程序进行扩展增强,比如完善其中的心跳检测、异常处理、资源关闭等,当然当前也有很多Socket通信的开源框架,如Netty、Grizzly、XSocket、Mina等,有有很好的实现,不想自己实现Socket的同学可以参考相关资料学习使用,如下为主要的实现类,完整代码请点击下载。
服务端实现类SocketServer:

客户端实现类SocketClient:

客户端管理类ClientManager

程序示例入口:
分别运行MainServer和MainClient,即可看到控制台打印的通信信息:


示例代码下载
完整代码,请点击下载,可独立运行。

被折叠的 条评论
为什么被折叠?



