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


Java AsynchronousSocketChannel.close方法代碼示例

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


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

示例1: startClient

import java.nio.channels.AsynchronousSocketChannel; //導入方法依賴的package包/類
@SuppressWarnings("resource")
public void startClient(SocketAddress addr, Object attachment, AsynchronousChannelGroup group)
{
	AsynchronousSocketChannel channel = null;
	try
	{
		channel = AsynchronousSocketChannel.open(group);
		int recvBufSize = onChannelCreated(channel, attachment);
		if(recvBufSize >= 0)
			channel.connect(addr, new ConnectParam(channel, recvBufSize), _connectHandler);
		else
			channel.close();
	}
	catch(Throwable e)
	{
		doException(null, e);
		closeChannel(channel);
	}
}
 
開發者ID:dwing4g,項目名稱:jane,代碼行數:20,代碼來源:TcpManager.java

示例2: cleanUpChannel

import java.nio.channels.AsynchronousSocketChannel; //導入方法依賴的package包/類
private void cleanUpChannel(AsynchronousSocketChannel channel) {
	try {
		if (channel != null) {
			channel.close();
		}
	} catch (Exception e){
		// Ignore
	}
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-systemtest,代碼行數:10,代碼來源:MultipleReadWriteFutureTest.java

示例3: testSingleConnect

import java.nio.channels.AsynchronousSocketChannel; //導入方法依賴的package包/類
public void testSingleConnect() throws IOException, ExecutionException, InterruptedException, TimeoutException {
	AsynchronousSocketChannel serverConnectionChannel = null;
	try {
		assertNotNull(serverAddress);

		serverConnectionChannel = AsynchronousSocketChannel.open();
		serverConnectionChannel.setOption(StandardSocketOptions.SO_REUSEADDR, true);
		
		// Ensure we have have returned an open connection
		assertNotNull(serverConnectionChannel);
		assertTrue("Channel is not open", serverConnectionChannel.isOpen());

		// Blocking connect
		Future<Void> future = serverConnectionChannel.connect(serverAddress);
		future.get(getTimeout(), TimeUnit.MILLISECONDS);
		
		// Ensure we are connected
		assertNotNull("Unable to get remote address", serverConnectionChannel.getRemoteAddress());
		
	} finally {
		if (serverConnectionChannel != null) {
			try {
				serverConnectionChannel.close();
			} catch (ClosedChannelException cce) {
				// That's ok
			}
			assertFalse("Channel was not closed", serverConnectionChannel.isOpen());
		}
	}
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-systemtest,代碼行數:31,代碼來源:MultipleConnectFutureTest.java

示例4: onClose

import java.nio.channels.AsynchronousSocketChannel; //導入方法依賴的package包/類
public static void onClose(AsynchronousSocketChannel asynchronousSocketChannel) throws IOException {
    outputBuffer = encodeUnmaskedFrame(1, "Connection Closed");
    outputBuffer.flip();
    outputBuffer.rewind();
    while (outputBuffer.hasRemaining()) {
        asynchronousSocketChannel.write(outputBuffer);
    }
    ByteBuffer closeBuffer = encodeUnmaskedFrame(8, "");
    closeBuffer.flip();
    while (closeBuffer.hasRemaining()) {
        asynchronousSocketChannel.write(closeBuffer);
    }
    connectionOpen = false;
    asynchronousSocketChannel.close();
}
 
開發者ID:ThreaT,項目名稱:WebServers,代碼行數:16,代碼來源:WebSocketServer.java

示例5: closeChannel

import java.nio.channels.AsynchronousSocketChannel; //導入方法依賴的package包/類
private static void closeChannel(AsynchronousSocketChannel channel) {
	if (channel == null) {
		return;
	}
	try {
		channel.close();
	} catch (IOException e) {
	}
}
 
開發者ID:youngor,項目名稱:openclouddb,代碼行數:10,代碼來源:NIOAcceptor.java

示例6: completed

import java.nio.channels.AsynchronousSocketChannel; //導入方法依賴的package包/類
@SuppressWarnings("resource")
@Override
public void completed(AsynchronousSocketChannel channel, Object attachment)
{
	beginAccept();
	TcpSession session = null;
	try
	{
		int recvBufSize = onChannelCreated(channel, attachment);
		if(recvBufSize < 0)
		{
			channel.close();
			return;
		}
		session = new TcpSession(TcpManager.this, channel, recvBufSize);
		_sessions.put(session, session);
		onSessionCreated(session);
		session.beginRecv();
	}
	catch(Throwable e)
	{
		doException(session, e);
		if(session != null)
			session.close(TcpSession.CLOSE_EXCEPTION);
		else
			closeChannel(channel);
	}
}
 
開發者ID:dwing4g,項目名稱:jane,代碼行數:29,代碼來源:TcpManager.java

示例7: testMultipleConnectSequential

import java.nio.channels.AsynchronousSocketChannel; //導入方法依賴的package包/類
public void testMultipleConnectSequential() throws IOException, ExecutionException, InterruptedException, TimeoutException {
	assertNotNull(serverAddress);
	System.out.println("MultipleConnectFutureTest.testMultipleConnectSequential() creating " +
			numberOfConnections + " connections");
	for (int counter = 0; counter < numberOfConnections; counter++) {
		HangNotifier.ping();
		AsynchronousSocketChannel serverConnectionChannel = null;
		try {
			serverConnectionChannel = AsynchronousSocketChannel.open();
			serverConnectionChannel.setOption(StandardSocketOptions.SO_REUSEADDR, true);
			
			// Ensure we have have returned an open connection
			assertNotNull(serverConnectionChannel);
			assertTrue("Channel is not open on iteration " + counter, serverConnectionChannel.isOpen());
	
			// Blocking connect
			Future<Void> future = serverConnectionChannel.connect(serverAddress);
			future.get(getTimeout(), TimeUnit.MILLISECONDS);
			
			// Ensure we are connected
			assertNotNull("Unable to get remote address on iteration " + counter, serverConnectionChannel.getRemoteAddress());
		} finally {
			if (serverConnectionChannel != null) {
				try {
					serverConnectionChannel.close();
				} catch (ClosedChannelException cce) {
					// That's ok
				} catch (IOException ioe) {
					throw ioe;
				}
				assertFalse("Channel was not closed on iteration " + counter, serverConnectionChannel.isOpen());
			}
		}
		
		// We can't hammer the server continuously, or we'll run out of resource.
		// Sleep before the test claims completion
		try {
			Thread.sleep(500);
		} catch (InterruptedException e) {}
	}
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-systemtest,代碼行數:42,代碼來源:MultipleConnectFutureTest.java

示例8: addNode

import java.nio.channels.AsynchronousSocketChannel; //導入方法依賴的package包/類
@RestMapping(name = "addnode", auth = false, comment = "動態增加指定Group的Node節點")
public RetResult addNode(@RestParam(name = "group", comment = "Group節點名") final String group,
    @RestParam(name = "addr", comment = "節點IP") final String addr,
    @RestParam(name = "port", comment = "節點端口") final int port) throws IOException {
    InetSocketAddress address;
    try {
        address = new InetSocketAddress(addr, port);
        AsynchronousSocketChannel channel = AsynchronousSocketChannel.open();
        channel.connect(address).get(2, TimeUnit.SECONDS);  //連接超時2秒
        channel.close();
    } catch (Exception e) {
        return new RetResult(RET_TRANSPORT_ADDR_ILLEGAL, "InetSocketAddress(addr=" + addr + ", port=" + port + ") is illegal or cannot connect");
    }
    if (transportFactory.findGroupName(address) != null) return new RetResult(RET_TRANSPORT_ADDR_ILLEGAL, "InetSocketAddress(addr=" + addr + ", port=" + port + ") is exists");
    synchronized (this) {
        if (transportFactory.findGroupInfo(group) == null) {
            return new RetResult(RET_TRANSPORT_GROUP_NOT_EXISTS, "not found group (" + group + ")");
        }
        transportFactory.addGroupInfo(group, address);
        for (Service service : transportFactory.getServices()) {
            if (!Sncp.isSncpDyn(service)) continue;
            SncpClient client = Sncp.getSncpClient(service);
            if (Sncp.isRemote(service)) {
                if (client.getRemoteGroups() != null && client.getRemoteGroups().contains(group)) {
                    client.getRemoteGroupTransport().addRemoteAddresses(address);
                }
            } else {
                if (group.equals(client.getSameGroup())) {
                    client.getSameGroupTransport().addRemoteAddresses(address);
                }
                if (client.getDiffGroups() != null && client.getDiffGroups().contains(group)) {
                    for (Transport transport : client.getDiffGroupTransports()) {
                        transport.addRemoteAddresses(address);
                    }
                }
            }
        }
        DefaultAnyValue node = DefaultAnyValue.create("addr", addr).addValue("port", port);
        for (AnyValue groupconf : application.getAppConfig().getAnyValue("resources").getAnyValues("group")) {
            if (group.equals(groupconf.getValue("name"))) {
                ((DefaultAnyValue) groupconf).addValue("node", node);
                break;
            }
        }
        application.restoreConfig();
    }
    return RetResult.success();
}
 
開發者ID:redkale,項目名稱:redkale,代碼行數:49,代碼來源:TransportWatchService.java


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