解决TCP socket的阻塞问题

大家知道,tcp的读和写是阻塞的,即读的时候不知道什么时候读完,写的时候不知道什么时候写完,因此线程就一直暂停在哪里,一般tcp程序用在上位机下位机之间对吧!下位机一些设备一般会发心跳报文给我们机器,假设为10s发一次吧,当机器超过10s没接收到数据,那么我们就要考虑把socket断开,因为不断开的话设备重新连接可能又会建立新的socket,这样如果设备反复断开连接的话,将产生大量的socket,占用大量系统资源,这里我们用socket.setSoTimeout(500)方法解决read方法的阻塞问题,同时设定一个标志位,在异常处理程序当中退出socket连接:

	public void run(){
    	InputStream is = null;
		OutputStream os = null;
		int flag = 0;
		try {
			socket.setSoTimeout(500); //  0.5秒就退出read()方法的阻塞
			is = socket.getInputStream();
			os = socket.getOutputStream();

		} catch (Exception e2) {
			e2.printStackTrace();
		}

	while (true) {
			try {
				// 读取数据
				int readlen = is.read(buff);
				if (readlen > 0) {
					flag = 0;
				}
				byte data[] = Arrays.copyOfRange(buff, 0, readlen);
				resolveData(data);
			} catch (IOException e) {
				try {

					flag++;
					if (flag == 200) {    
						is.close();
						os.close();
						socket.close();

					}
				} catch (Exception e1) {
					e1.printStackTrace();
				}

			}
		}
		}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章