Java网络通信中ServerSocket的设计优化方案
作者:Kikityer 时间:2023-06-14 08:25:53
前言:在java的网络通信中,两个不同节点的主机想要进行通信则可以通过建立Socket对象(相当于客户端主机,向服务端请求发送信息)和ServerSocket对象(相当于服务端主机,接收客户端的连接请求并回复信息)实现。
1:创建一个Socket对象
Socket socket = new Socket("IP",port);
指定将要连接的服务端的ip地址和端口号来创建一个Socket对象,在创建结束之后便可对其进行输出、输入操作。
2:创建一个ServerSocket对象
ServerSocket sever = new ServerSocket(port); //此端口为客户端连接的端口
Socket connnection = server.accept(); //阻塞在此监听上方的端口,一但有连接请求就做出处理。
创建一个新的ServerSocket对象,并让这个对象阻塞监听客户端连接的指定的端口,一但有新的连接请求则做出处理。
基本的一个关系是:Socket ------------------->ServerSocket
此时只要来一个连接服务端就阻塞做出处理,等到处理结束之后重新处以监听端口状态,要是又来一个新的连接请求则......一直往复处理动作。明显的缺点是效率低,每次只能处理一个请求,并且是阻塞处理状态。
优化处理:
BIO中开启多线程,每来一个请求服务端就开启一个线程处理。(优点是可以提高效率,但是缺点也很明显:优点大量几乎同时入站连接可能导致它生成极大数量的线程。最终,java虚拟机会消耗内存二崩溃)。
对于上面的方案做出改进:BIO中使用线程池管理线程。(可以处理效率同时避免了服务器因为高并发的连接而崩溃)。
使用NIO。(NIO虽然也是单个线程去处理连接请求,但是不会阻塞,会不停地轮询是否有就绪的事件,所以处理的顺序和连接请求的先后顺序无关,与请求数据到来的先后顺序有关。一个线程中就可以调用多路复用接口(select)阻塞同时监听来自多个客户端的IO请求,一旦有收到IO请求就调用对应函数处理)
来源:https://blog.csdn.net/weixin_40581455/article/details/84539716
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Java动态代理模式的深入揭秘
![](https://img.aspxhome.com/file/2023/9/113249_0s.jpg)
java二维数组指定不同长度实例方法
Android仿微信activity滑动关闭效果
Android学习笔记--使用剪切板在Activity中传值示例代码
详解Java图形化编程中的鼠标事件设计
C#计算两个文件的相对目录算法的实例代码
使用Maven配置Spring的方法步骤
完整的iOS新浪微博分享功能开发
![](https://img.aspxhome.com/file/2023/7/101967_0s.png)
Android Studio和阿里云数据库实现一个远程聊天程序
![](https://img.aspxhome.com/file/2023/4/92614_0s.jpg)
Java解析xml文件遇到特殊符号异常的情况(处理方案)
Android应用启动另外一个apk应用的方法
Spring创建bean实例的几种方式分享
详解C#中的定时器Timer类及其垃圾回收机制
深入了解Java中finalize方法的作用和底层原理
![](https://img.aspxhome.com/file/2023/6/78986_0s.png)
Android应用开发中模拟按下HOME键的效果(实现代码)
Android实现密码明密文切换(小眼睛)
![](https://img.aspxhome.com/file/2023/8/128998_0s.jpg)
详解房卡麻将分析系列 "牌局回放" 之 播放处理
![](https://img.aspxhome.com/file/2023/9/137359_0s.jpg)
总结C#删除字符串数组中空字符串的几种方法
![](https://img.aspxhome.com/file/2023/9/129679_0s.jpg)
C# Word 类库的深入理解
SpringBoot定时任务多线程实现示例
![](https://img.aspxhome.com/file/2023/1/71021_0s.png)