1:Client类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23import java.io.IOException; import java.net.Socket; import java.net.UnknownHostException; public class Client { public static void main(String args[]) throws UnknownHostException, IOException, InterruptedException { final int length = 100; String host = "localhost"; int port = 8000; Socket[] sockets = new Socket[length]; for(int i = 0; i < length; i++) { sockets[i] = new Socket(host, port); System.out.println("the " + (i+1) + "connection is successful"); } Thread.sleep(3000); for(int i = 0; i < length; i++) { sockets[i].close(); } } }
2:Server类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; public class Server { private int port = 8000; private int server_num = 3; private static ServerSocket serverSocket; public Server() throws IOException { serverSocket = new ServerSocket(port, server_num); System.out.println("The server is starting"); } public void service() { while(true) { Socket socket = null; try { socket = serverSocket.accept(); System.out.println("new connection is completed " + socket.getInetAddress() + ":" + socket.getPort()); } catch(IOException e) { e.printStackTrace(); } finally { if(socket != null) { try { socket.close(); } catch (IOException e) { e.printStackTrace(); } } } } } public static void main(String args[]) throws IOException, InterruptedException { Server server = new Server(); Thread.sleep(60000*10); server.service(); } }
3:程序结果
当Thread.sleep(60000*10)被注释时,Client端的效果为
Server端的效果为:
当server.service();被注释时,client端的效果为:
4:结果解析
*当server.service()方法被注释后,使得服务器与8000端口绑定后,永远不会执行serverSocket.accept()方法,这意味着队列中的连接请求永远不会被取出。
*当Thread.sleep(60000*10)被注释后,使得服务器与8000端口绑定后,就会在一个while循环中不断执行serverSocket.accept()方法,该方法从队列中取出连接请求,使得队列能够及时的腾出空间,以容纳新的连接请求。
5:补充小程序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21import java.io.IOException; import java.net.ServerSocket; public class testServerSocket { public static void main(String[] args) { ServerSocket serverSocket = null; for(int i = 0; i < 65535; i++) { try { serverSocket = new ServerSocket(i); serverSocket.close(); } catch (IOException e) { e.printStackTrace(); System.out.println("端口" + i + "已经被其他服务器进程占用"); } } } }
该程序循环判断1到65535的端口有没有被占用,当被占用时会打印输出被占用的端口号
ServerSocket的几个方法
*isClosed():判断serverSocket是否已经被关闭,只有执行了ServerSocket的close方法,isClosed()方法才返回true,否则,即使ServerSocket还没有和特定的端口绑定,isClosed方法也会返回false
*isBound():判断ServerSocket方法是否已经与一个端口绑定,只要ServerSocket已经和一个端口绑定,即使它已经被关闭,isBound()也会返回true
*如果需要判断一个ServerSocket已经与特定端口绑定,并且还没有被关闭,则可以采用下列方式:
boolean isOpen = serverSocket.isBound() && !serverSocket.isClosed()
最后
以上就是迷人高山最近收集整理的关于ServerSocket的一个简单例子,学习backlog参数的设置,即可以接受客户端的数量的全部内容,更多相关ServerSocket内容请搜索靠谱客的其他文章。
发表评论 取消回复