當前位置: 首頁>>代碼示例>>Java>>正文


Java SocketChannel.isOpen方法代碼示例

本文整理匯總了Java中java.nio.channels.SocketChannel.isOpen方法的典型用法代碼示例。如果您正苦於以下問題:Java SocketChannel.isOpen方法的具體用法?Java SocketChannel.isOpen怎麽用?Java SocketChannel.isOpen使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.nio.channels.SocketChannel的用法示例。


在下文中一共展示了SocketChannel.isOpen方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: writeData

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private void writeData(
        RequestContext requestContext,
        Function<RequestContext, ByteBuffer> toByteBuffer) {

    SocketChannel socketChannel = requestContext.getSocketChannel();
    if (!socketChannel.isOpen()) {
        LOG.info("SocketChannel closed. Not writing.");
        return;
    }

    try {
        ByteBuffer byteBuffer = toByteBuffer.apply(requestContext);
        int size = byteBuffer.position();
        byteBuffer.flip();

        while (byteBuffer.hasRemaining()) {
            socketChannel.write(byteBuffer);
        }
        LOG.info("Write finished: " + size + " bytes.");
    } catch (IOException e) {
        LOG.error("Error writing data", e);
        CloseableUtils.close(socketChannel);
    }
}
 
開發者ID:yiding-he,項目名稱:java-nio-test,代碼行數:25,代碼來源:SocketChannelWriter.java

示例2: closeBlocking

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
@Override
public void closeBlocking() throws InterruptedException {
    super.closeBlocking();
    try {
        Field channelField = this.getClass().getSuperclass().getDeclaredField("channel");
        channelField.setAccessible(true);
        SocketChannel channel = (SocketChannel) channelField.get(this);
        if (channel != null && channel.isOpen()) {
            Socket socket = channel.socket();
            if (socket != null)
                    socket.close();
        }
    }
    catch (Exception ex) {
        System.out.println("Exception in Websocket close hack.");
        ex.printStackTrace();
    }
}
 
開發者ID:ZhouKanZ,項目名稱:SweepRobot,代碼行數:19,代碼來源:ROSBridgeWebSocketClient.java

示例3: createOrReuseSocket

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public SocketChannel createOrReuseSocket(InetAddress inetAddress, int port) throws IOException {
	String key = NIOHandler.makeKey(inetAddress, port);
	SocketChannel channel = null;
	keyedSemaphore.enterIOCriticalSection(key);
	try {
		channel = getSocket(key);
		if(channel != null && (!channel.isConnected() || !channel.isOpen())) {
			if(logger.isLoggingEnabled(LogWriter.TRACE_DEBUG))
				logger.logDebug("Channel disconnected " + channel);
			channel = null;
		}
		if(channel == null) { // this is where the threads will race
			SocketAddress sockAddr = new InetSocketAddress(inetAddress, port);
			channel = messageProcessor.blockingConnect((InetSocketAddress) sockAddr, 10000);
			if(logger.isLoggingEnabled(LogWriter.TRACE_DEBUG))
				logger.logDebug("create channel = " + channel + "  " + inetAddress + " " + port);
			if(channel != null && channel.isConnected()) {
				putSocket(NIOHandler.makeKey(inetAddress, port), channel);
				if(logger.isLoggingEnabled(LogWriter.TRACE_DEBUG))
					logger.logDebug("channel cached channel = " + channel);
			}
		} 
		return channel;
	} finally {
		keyedSemaphore.leaveIOCriticalSection(key);
		if(logger.isLoggingEnabled(LogWriter.TRACE_DEBUG))
logger.logDebug("Returning socket " + key + " channel = " + channel);
	}
}
 
開發者ID:YunlongYang,項目名稱:LightSIP,代碼行數:30,代碼來源:NIOHandler.java

示例4: connect

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
/**
 * The contract is similar to {@link SocketChannel#connect(SocketAddress)} 
 * with a timeout.
 * 
 * @see SocketChannel#connect(SocketAddress)
 * 
 * @param channel - this should be a {@link SelectableChannel}
 * @param endpoint
 * @throws IOException
 */
static void connect(SocketChannel channel, 
                    SocketAddress endpoint, int timeout) throws IOException {
  
  boolean blockingOn = channel.isBlocking();
  if (blockingOn) {
    channel.configureBlocking(false);
  }
  
  try { 
    if (channel.connect(endpoint)) {
      return;
    }

    long timeoutLeft = timeout;
    long endTime = (timeout > 0) ? (Time.now() + timeout): 0;
    
    while (true) {
      // we might have to call finishConnect() more than once
      // for some channels (with user level protocols)
      
      int ret = selector.select((SelectableChannel)channel, 
                                SelectionKey.OP_CONNECT, timeoutLeft);
      
      if (ret > 0 && channel.finishConnect()) {
        return;
      }
      
      if (ret == 0 ||
          (timeout > 0 &&  
            (timeoutLeft = (endTime - Time.now())) <= 0)) {
        throw new SocketTimeoutException(
                  timeoutExceptionString(channel, timeout, 
                                         SelectionKey.OP_CONNECT));
      }
    }
  } catch (IOException e) {
    // javadoc for SocketChannel.connect() says channel should be closed.
    try {
      channel.close();
    } catch (IOException ignored) {}
    throw e;
  } finally {
    if (blockingOn && channel.isOpen()) {
      channel.configureBlocking(true);
    }
  }
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:58,代碼來源:SocketIOWithTimeout.java

示例5: connect

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
/**
 * The contract is similar to {@link SocketChannel#connect(SocketAddress)} 
 * with a timeout.
 * 
 * @see SocketChannel#connect(SocketAddress)
 * 
 * @param channel - this should be a {@link SelectableChannel}
 * @param endpoint
 * @throws IOException
 */
static void connect(SocketChannel channel, 
                    SocketAddress endpoint, int timeout) throws IOException {
  
  boolean blockingOn = channel.isBlocking();
  if (blockingOn) {
    channel.configureBlocking(false);
  }
  
  try { 
    if (channel.connect(endpoint)) {
      return;
    }

    long timeoutLeft = timeout;
    long endTime = (timeout > 0) ? (System.currentTimeMillis() + timeout): 0;
    
    while (true) {
      // we might have to call finishConnect() more than once
      // for some channels (with user level protocols)
      
      int ret = selector.select((SelectableChannel)channel, 
                                SelectionKey.OP_CONNECT, timeoutLeft);
      
      if (ret > 0 && channel.finishConnect()) {
        return;
      }
      
      if (ret == 0 ||
          (timeout > 0 &&  
            (timeoutLeft = (endTime - System.currentTimeMillis())) <= 0)) {
        throw new SocketTimeoutException(
                  timeoutExceptionString(channel, timeout, 
                                         SelectionKey.OP_CONNECT));
      }
    }
  } catch (IOException e) {
    // javadoc for SocketChannel.connect() says channel should be closed.
    /*try {
      channel.close();
    } catch (IOException ignored) {}*/
    throw e;
  } finally {
    if (blockingOn && channel.isOpen()) {
      channel.configureBlocking(true);
    }
  }
}
 
開發者ID:spafka,項目名稱:spark_deep,代碼行數:58,代碼來源:SocketIOWithTimeout.java


注:本文中的java.nio.channels.SocketChannel.isOpen方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。