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


Java SocketChannel.open方法代碼示例

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


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

示例1: testStartConnection

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
/**
 * testStartConnection
 */
@Test
public void testStartConnection() throws Exception {
    System.err.println("testStartConnection()");
    for (final HStoreCoordinator m : this.coordinators) {
        // Check that the messenger state is correct
        assert (m.isStarted());

        // Check that the messenger's listener thread is running
        assert (m.getListenerThread().isAlive());

        // Check that we can connect to the messenger's listening port
        int port = m.getLocalMessengerPort();
        SocketChannel channel = SocketChannel.open();
        channel.connect(new InetSocketAddress(port));
        assert (channel.isConnected());
    } // FOR
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:21,代碼來源:TestHStoreCoordinator.java

示例2: open

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
/**
 * Open client socket and connect to given address and port.
 *
 * @param address Address to connect to.
 * @param port Port to connect to.
 * @return {@link TCPClientSocket}
 * @throws IOException If an I/O error occurs.
 */
static TCPClientSocketImpl open(String address, int port) throws IOException {

    TCPClientSocketImpl clientSocket = null;
    try {
        clientSocket = new TCPClientSocketImpl(SocketChannel.open());
        clientSocket.socketChannel.socket().setSoTimeout(DEFAULT_SOCKET_TIMEOUT_IN_MS);
        clientSocket.socketChannel.connect(new InetSocketAddress(address, port));
        clientSocket.socketChannel.configureBlocking(false);
    } catch(Exception e) {
        if (clientSocket != null) {
            clientSocket.close();
        }
        throw e;
    }

    return clientSocket;
}
 
開發者ID:cpppwner,項目名稱:NoRiskNoFun,代碼行數:26,代碼來源:TCPClientSocketImpl.java

示例3: testClientReconnect

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
@Test
public void testClientReconnect() throws IOException, InterruptedException {
    HostProvider hostProvider = mock(HostProvider.class);
    when(hostProvider.size()).thenReturn(1);
    InetSocketAddress inaddr = new InetSocketAddress(1111);
    when(hostProvider.next(anyLong())).thenReturn(inaddr);
    ZooKeeper zk = mock(ZooKeeper.class);
    sc =  SocketChannel.open();

    ClientCnxnSocketNIO nioCnxn = new MockCnxn();
    ClientWatchManager watcher = mock(ClientWatchManager.class);
    ClientCnxn clientCnxn = new ClientCnxn(
            "tmp", hostProvider, 5000,
            zk, watcher, nioCnxn, false);
    clientCnxn.start();
    countDownLatch.await(5000, TimeUnit.MILLISECONDS);
    Assert.assertTrue(countDownLatch.getCount() == 0);
    clientCnxn.close();
}
 
開發者ID:maoling,項目名稱:fuck_zookeeper,代碼行數:20,代碼來源:ClientReconnectTest.java

示例4: main

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public static void main(String[] argv) throws Exception {
    try (ByteServer server = new ByteServer();
         SocketChannel sc = SocketChannel.open(server.address())) {

        server.acceptConnection();

        try (Selector sel = Selector.open()) {
            sc.configureBlocking(false);
            sc.register(sel, SelectionKey.OP_WRITE);
            sel.select();
            sel.selectedKeys().clear();
            if (sel.select() == 0) {
                throw new Exception("Select returned zero");
            }
        }
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:18,代碼來源:SelectWrite.java

示例5: run

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public void run(Consumer<HttpResponse> consumer) throws IOException {
System.out.println("Expecting a response after GET from: " + this.url.toString() + "\n\n");
try (SocketChannel socketChannel = SocketChannel.open(this.address)) {
    socketChannel.configureBlocking(true);
    writeGetRequestTo(socketChannel);
    HttpResponseReader.fromChannel(socketChannel).findFirst().ifPresent(consumer);

}
System.out.println("Demo end");
   }
 
開發者ID:Oliver-Loeffler,項目名稱:NIOHttp,代碼行數:11,代碼來源:StreamDemo.java

示例6: run

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private void run() throws Exception
{
	NioThread nt=new NioThread();
	nt.start();
	Thread.sleep(1000);
	SocketChannel sc=SocketChannel.open();
	sc.configureBlocking(false);
	sc.connect(new InetSocketAddress("localhost", 9999));
	ChannelProcessorMultiplexer m=new ChannelProcessorMultiplexer(nt, sc, true,
			VideoServerTCPListener.clientID.getBytes(StandardCharsets.UTF_8),
			VideoServerTCPListener.serverID.getBytes(StandardCharsets.UTF_8));
	m.start();
	new ConnectToStdout(m);
}
 
開發者ID:rizsi,項目名稱:rcom,代碼行數:15,代碼來源:ExampleNioStdoutClient.java

示例7: FDTNetPerfClient

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
FDTNetPerfClient(String host, int port) throws Exception {
    this();
    this.sc = SocketChannel.open();
    this.sc.configureBlocking(true);
    this.sc.socket().connect(new InetSocketAddress(InetAddress.getByName(host), port));
    shouldWrite = true;
}
 
開發者ID:fast-data-transfer,項目名稱:fdt,代碼行數:8,代碼來源:FDTNetPerf.java

示例8: Tunnel

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public Tunnel(InetSocketAddress serverAddress,Selector selector) throws IOException{
	SocketChannel innerChannel=SocketChannel.open();
	innerChannel.configureBlocking(false);
	this.m_InnerChannel=innerChannel;
	this.m_Selector=selector;
	this.m_ServerEP=serverAddress;
	SessionCount++;
}
 
開發者ID:w22ee,項目名稱:onekey-proxy-android,代碼行數:9,代碼來源:Tunnel.java

示例9: get

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
@Override
public SocketChannel get(int retryNumber, Throwable lastError) {
    if(lastError != null) {
        logger.error(lastError.getMessage(), lastError);
    }
    try {
        return SocketChannel.open(new InetSocketAddress(host, port));
    } catch (IOException e) {
        throw new IllegalStateException(e.getMessage(), e);
    }
}
 
開發者ID:saladinkzn,項目名稱:spring-data-tarantool,代碼行數:12,代碼來源:SimpleSocketChannelProvider.java

示例10: main

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public static void main(String[] argv) throws Exception {
    try (ByteServer server = new ByteServer();
         SocketChannel sc = SocketChannel.open(server.address())) {

        server.acceptConnection();

        try (Selector sel = Selector.open()) {
            sc.configureBlocking(false);
            sc.register(sel, SelectionKey.OP_READ);
            // Previously channel would get selected here, although there is nothing to read
            if (sel.selectNow() != 0)
                throw new Exception("Select returned nonzero value");
        }
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:16,代碼來源:ReadAfterConnect.java

示例11: init

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public void init() throws Exception {

        sel = Selector.open();

        InetSocketAddress addr = new InetSocketAddress(serverHost, serverPort);
        for (int i = 0; i < sockNum; i++) {
            SocketChannel sc = SocketChannel.open();

            sc.configureBlocking(false);

            System.out.println("initiating connection");

            sc.connect(addr);

            // TODO ... for the moment there is a 1-1 mapping between "filling threads" and number of sockets ...
            Thread t = new Thread(new FillingTask());
            t.setDaemon(true);
            t.start();

            while (!sc.finishConnect()) {
                // TODO - do something useful
                try {
                    Thread.sleep(100);
                } catch (Exception ex) {
                }
                ;
            }

            System.out.println("connection established");
            sc.register(sel, SelectionKey.OP_WRITE);
        }

    }
 
開發者ID:fast-data-transfer,項目名稱:fdt,代碼行數:34,代碼來源:JIperfClient.java

示例12: SocketChannelHelper

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public SocketChannelHelper(String address, int port)
 	{
 		this.address = address;
 		this.port = port;

 		try
 		{
	this.channel = SocketChannel.open(new InetSocketAddress(address, port));
}
 		catch (IOException e)
 		{
	e.printStackTrace();
}
 	}
 
開發者ID:Yarichi,項目名稱:Proyecto-DASI,代碼行數:15,代碼來源:TCPSocketHelper.java

示例13: main

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    InetAddress lh = InetAddress.getLocalHost();
    InetSocketAddress isa = new InetSocketAddress(lh, 12345);

    System.setSecurityManager( new SecurityManager() );
    for (int i=0; i<100000; i++) {
        try {
            SocketChannel.open(isa);
            throw new RuntimeException("This should not happen");
        } catch (SecurityException x) { }
    }

}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:14,代碼來源:OpenLeak.java

示例14: initClient

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public void initClient(String ip, int port) throws IOException { // 獲得一個Socket通道
    SocketChannel channel = SocketChannel.open(); // 設置通道為非阻塞
    channel.configureBlocking(false); // 獲得一個通道管理器
    this.selector = Selector.open(); // 客戶端連接服務器,其實方法執行並沒有實現連接,需要在listen()方法中調
    channel.connect(new InetSocketAddress(ip, port));
    channel.register(selector, SelectionKey.OP_CONNECT);
}
 
開發者ID:laidu,項目名稱:java-learn,代碼行數:8,代碼來源:NioClient.java

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


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