Socket通信 一个服务器对多个客户端,不能延迟接受信息的实现

实验对象:
三个客户端,一个端口对应一个客户端,分别是6020 6080 6021;
6020 和6021下面没有手环,也就是说没有数据发送过来;
实验要求:
1.一个时间点,无论哪个基站有数据发送,服务器必须同时接收。不能延迟等待这个客户端接收完毕再接收另一个客户端;
2.客户端不能关闭,一直连接,以防数据遗漏
3.多个客户端,如果只有一个客户端发送数据,会不会等待延迟?
知识点:
多线程 同时开启多个任务,不用按照程序的执行顺序来;
基本的代码如下:

package cn.com.project;
import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
public class Crc{
	public static StringBuilder stringBuilder=null;
	public static int i=0;
	public static int h=0;
	public static String sz[]=null;
	//1,循环的基站
	public static void main(String[] args) {
		Port();
				}

public static void Port(){
	try {
		new Thread(new ThreadReader(new ServerSocket(6020))).start();
		new Thread(new ThreadReader(new ServerSocket(6080))).start();
		new Thread(new ThreadReader(new ServerSocket(6021))).start();
	} catch (IOException e1) {
		
	}
}
	}

其他的代码见上一篇博客
实验结果:
在这里插入图片描述
在这里插入图片描述
结论:
以上程序:
及时多个客户端只有一个客户端发送数据,也不影响执行时间;
服务器可以同步接受客户端信息,无延迟;
客户端可以一直发送数据,即使没有数据也会一直开着的!!
缺陷:
一个客户端下面有15个手卡,全部接受完毕需要6分钟,耗时太长!!!

猜你喜欢

转载自blog.csdn.net/qq_37591637/article/details/82924522