Socket笔记之Read timed out深入分析

ReadTimedOut深入分析

  1. Read timed out就是已经连接成功,但是服务器没有及时返回数据,导致读超时。

  2. java程序模拟Read timed out

    服务端
    public class SimpleServer {
         
         
        public static void main(String[] args) throws IOException, InterruptedException {
         
         
            ServerSocket serverSocket = new ServerSocket(8888,200);
            Thread.sleep(6666666);
        }
    }
    
    //客户端程序
    @Test
    public void testReadTimeOut() {
         
         
        Socket socket = new Socket();
        long startTime = 0;
        try {
         
         
            socket.connect(new InetSocketAddress("127.0.0.1", 8888), 10000);
            System.out.println("socket连接成功....");
            socket.setSoTimeout(2000);
            startTime = System.currentTimeMillis();
            int read = socket.getInputStream().read();
        } catch (IOException e) {
         
         
            e.printStackTrace();
        } finally {
         
         
            long endTime = System.currentTimeMillis();
            System.out.println(endTime - startTime);
        }
    
    }           
    

    执行结果

     	socket连接成功....
    	执行时间:2008
    	java.net.SocketTimeoutException: Read timed out
    		at java.net.SocketInputStream.socketRead0(Native Method)
    		at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
    		at java.net.SocketInputStream.read(SocketInputStream.java:170)
    		at java.net.SocketInputStream.read(SocketInputStream.java:141)
    		at java.net.SocketInputStream.read(SocketInputStream.java:
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值