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


Java SocketChannel.isConnected方法代碼示例

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


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

示例1: 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

示例2: main

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    ServerSocketChannel ssc = ServerSocketChannel.open();
    ssc.socket().bind(new InetSocketAddress(0));

    InetAddress lh = InetAddress.getLocalHost();
    final SocketChannel sc = SocketChannel.open();
    final InetSocketAddress isa =
        new InetSocketAddress(lh, ssc.socket().getLocalPort());

    // establish connection in another thread
    Runnable connector =
        new Runnable() {
            public void run() {
                try {
                    sc.connect(isa);
                } catch (IOException ioe) {
                    ioe.printStackTrace();
                }
            }
        };
    Thread thr = new Thread(connector);
    thr.start();

    // wait for connect to be established and for thread to
    // terminate
    do {
        try {
            thr.join();
        } catch (InterruptedException x) { }
    } while (thr.isAlive());

    // check connection is established
    if (!sc.isConnected()) {
        throw new RuntimeException("SocketChannel not connected");
    }

    // close channel - this triggered the bug as it attempted to signal
    // a thread that no longer exists
    sc.close();

    // clean-up
    ssc.accept().close();
    ssc.close();
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:45,代碼來源:CloseAfterConnect.java

示例3: moveDataIntoIndividualChannelBuffers

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private int moveDataIntoIndividualChannelBuffers()
{
	byte[] dst = {};
	synchronized( buffer )
	{
		if (buffer.position() == 0)
			return 0;

		buffer.flip();
		dst = new byte[buffer.remaining()];
		buffer.get(dst);
		buffer.compact();
	}

	for( SocketChannel chan : connectionBuffers.keySet() )
	{
	  if(!chan.isConnected())
	  {
	    connectionBuffers.remove(chan);
	    continue;
	  }
	  ByteBuffer connectionBuffer = connectionBuffers.get(chan);
		try
		{
			if( connectionBuffer.remaining() > dst.length )
			{
				connectionBuffer.put(dst);
				haveDataInIndividualBuffers = true;
			}
			else
			{
				String remoteClientAddress = chan.toString();
				log.error( "Overflow while trying to write to the output buffer associated with address "+remoteClientAddress+".");
			}
		}catch(BufferOverflowException ex)
		{
			log.error( "Overflow while trying to write to an output buffer.");
		}
	}
	return dst.length;

}
 
開發者ID:Esri,項目名稱:defense-solutions-proofs-of-concept,代碼行數:43,代碼來源:TcpSquirtOutboundTransport.java


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