原文地址:https://blog.csdn.net/acmman/article/details/80039159
1.编写服务端代码
package com.bootdo.test.socket;
import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
/**
* socket服务端
* IO_Server
*/
public class IO_Server {
public static void main(String[] args) throws IOException {
//创建一个缓存线程池可以连接多个客户端,但是十分消耗性能
//ExecutorService newCachedThreadPool = Executors.newCachedThreadPool();
//创建Socket服务,监听10010端口
ServerSocket serverSocket = new ServerSocket(10010);
System.out.println("服务端启动!");
while (true){
//获取一个套接字(阻塞)
/**
* 1.在客户端没有连接进来的时候,服务端会在server.accept();的位置阻塞等待
* 2.然后使用Windows的CMD控制台的telnet进行客户端连接:telnet 127.0.0.1 10010
*/
final Socket socket = serverSocket.accept();
System.out.println("出现一个新客户端!");
/*newCachedThreadPool.execute(new Runnable() {
@Override
public void run() {
//业务处理
handler(socket);
}
});*/
//业务处理
handler(socket);
}
}
/**
* 读取数据
* @param socket
*/
private static void handler(Socket socket){
try {
byte[] bytes = new byte[1024];
InputStream input =socket.getInputStream();
int read = 0;
while (read!=-1){
//读取数据(阻塞)
/**
* 1.当程序走到read = input.read(bytes);发生了阻塞等待,等待客户端传输信息:
* 2.此时在阻塞过程中,意味着这条线程是被这个Socket一直占用着的,
* 其它的Socket不能进来。(再次打开一个CMD控制台使用telnet,可以发现进不来)
*/
read=input.read(bytes);
System.out.println(new String(bytes,0,read));
}
} catch (IOException e) {
e.printStackTrace();
}finally{
try {
System.out.println("socket 关闭");
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
*使用Debug模式运行该程序
2.客户端
2-1:Windows的CMD控制台的telnet进行客户端连接:
(如果提示'telnet' 不是内部或外部命令,也不是可运行的程序,请参考如下设置)
2-2:可以看到阻塞的
程序向下走了
*当程序走到read = input.read(bytes);发生了阻塞等待,等待客户端传输信息,此时在阻塞过程中,意味着这条线程是被这个Socket一直占用着的,其它的Socket不能进来,当我们在CMD中输入信息后,可以看到服务端收到了信息