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


Java Selector.selectNow方法代碼示例

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


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

示例1: main

import java.nio.channels.Selector; //導入方法依賴的package包/類
public static void main(String[] args) throws IOException {
    Selector sel = Selector.open();
    SocketChannel sc = SocketChannel.open();
    sc.configureBlocking(false);
    SelectionKey key = sc.register(sel, 0);
    for (int i=0; i<50000; i++) {
        key.interestOps(0);
    }
    sel.selectNow();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:11,代碼來源:LotsOfUpdates.java

示例2: write

import java.nio.channels.Selector; //導入方法依賴的package包/類
public int write(ByteBuffer buf, NioChannel socket, Selector selector, long writeTimeout, boolean block)
		throws IOException {
	if (SHARED && block) {
		return blockingSelector.write(buf, socket, writeTimeout);
	}
	SelectionKey key = null;
	int written = 0;
	boolean timedout = false;
	int keycount = 1; // assume we can write
	long time = System.currentTimeMillis(); // start the timeout timer
	try {
		while ((!timedout) && buf.hasRemaining()) {
			int cnt = 0;
			if (keycount > 0) { // only write if we were registered for a
								// write
				cnt = socket.write(buf); // write the data
				if (cnt == -1)
					throw new EOFException();

				written += cnt;
				if (cnt > 0) {
					time = System.currentTimeMillis(); // reset our timeout
														// timer
					continue; // we successfully wrote, try again without a
								// selector
				}
				if (cnt == 0 && (!block))
					break; // don't block
			}
			if (selector != null) {
				// register OP_WRITE to the selector
				if (key == null)
					key = socket.getIOChannel().register(selector, SelectionKey.OP_WRITE);
				else
					key.interestOps(SelectionKey.OP_WRITE);
				keycount = selector.select(writeTimeout);
			}
			if (writeTimeout > 0 && (selector == null || keycount == 0))
				timedout = (System.currentTimeMillis() - time) >= writeTimeout;
		} // while
		if (timedout)
			throw new SocketTimeoutException();
	} finally {
		if (key != null) {
			key.cancel();
			if (selector != null)
				selector.selectNow();// removes the key from this selector
		}
	}
	return written;
}
 
開發者ID:how2j,項目名稱:lazycat,代碼行數:52,代碼來源:NioSelectorPool.java

示例3: select

import java.nio.channels.Selector; //導入方法依賴的package包/類
private void select() throws IOException {
    Selector selector = this.selector;
    try {
        int selectCnt = 0;
        long currentNanoTime = System.nanoTime();
        long selectDeadLineNanos = currentNanoTime + TimeUnit.SECONDS.toNanos(1);
        for (;;) {
            long timeoutMillis = (selectDeadLineNanos - currentNanoTime + 500000L) / 1000000L;
            if (timeoutMillis <= 0) {
                if (selectCnt == 0) {
                    selector.selectNow();
                    selectCnt = 1;
                }
                break;
            }

            int selectedKeys = selector.select(timeoutMillis);
            selectCnt++;

            if (selectedKeys != 0) {
                break;
            }

            if (selectCnt >= SELECTOR_AUTO_REBUILD_THRESHOLD) {
                LOGGER.warn("Selector.select() returned prematurely {} times in a row; rebuilding selector.", selectCnt);

                rebuildSelector();
                selector = this.selector;

                // 重新select,填充 selectedKeys
                selector.selectNow();
                selectCnt = 1;
                break;
            }

            currentNanoTime = System.nanoTime();
        }

        if (selectCnt > MIN_PREMATURE_SELECTOR_RETURNS) {
            if (LOGGER.isDebugEnabled()) {
                LOGGER.debug("Selector.select() returned prematurely {} times in a row.", selectCnt - 1);
            }
        }
    } catch (CancelledKeyException e) {
        if (LOGGER.isDebugEnabled()) {
            LOGGER.debug(CancelledKeyException.class.getSimpleName() + " raised by a Selector - JDK bug?", e);
        }
    }
}
 
開發者ID:lemonJun,項目名稱:TakinRPC,代碼行數:50,代碼來源:NioSelectorLoop.java

示例4: write

import java.nio.channels.Selector; //導入方法依賴的package包/類
public int write(ByteBuffer buf, NioChannel socket, Selector selector,
                 long writeTimeout, boolean block) throws IOException {
    if ( SHARED && block ) {
        return blockingSelector.write(buf,socket,writeTimeout);
    }
    SelectionKey key = null;
    int written = 0;
    boolean timedout = false;
    int keycount = 1; //assume we can write
    long time = System.currentTimeMillis(); //start the timeout timer
    try {
        while ( (!timedout) && buf.hasRemaining() ) {
            int cnt = 0;
            if ( keycount > 0 ) { //only write if we were registered for a write
                cnt = socket.write(buf); //write the data
                if (cnt == -1) throw new EOFException();

                written += cnt;
                if (cnt > 0) {
                    time = System.currentTimeMillis(); //reset our timeout timer
                    continue; //we successfully wrote, try again without a selector
                }
                if (cnt==0 && (!block)) break; //don't block
            }
            if ( selector != null ) {
                //register OP_WRITE to the selector
                if (key==null) key = socket.getIOChannel().register(selector, SelectionKey.OP_WRITE);
                else key.interestOps(SelectionKey.OP_WRITE);
                keycount = selector.select(writeTimeout);
            }
            if (writeTimeout > 0 && (selector == null || keycount == 0) ) timedout = (System.currentTimeMillis()-time)>=writeTimeout;
        }//while
        if ( timedout ) throw new SocketTimeoutException();
    } finally {
        if (key != null) {
            key.cancel();
            if (selector != null) selector.selectNow();//removes the key from this selector
        }
    }
    return written;
}
 
開發者ID:liaokailin,項目名稱:tomcat7,代碼行數:42,代碼來源:NioSelectorPool.java

示例5: runTest

import java.nio.channels.Selector; //導入方法依賴的package包/類
static void runTest(int initCount, int massCount, int maxSelectTime)
        throws Exception {
    testStartTime = System.nanoTime();

    InetSocketAddress address = new InetSocketAddress("127.0.0.1", 7359);

    // Create server channel, add it to selector and run epoll_ctl.
    log("Setting up server");
    Selector serverSelector = Selector.open();
    ServerSocketChannel server = ServerSocketChannel.open();
    server.configureBlocking(false);
    server.socket().bind(address, 5000);
    server.register(serverSelector, SelectionKey.OP_ACCEPT);
    serverSelector.selectNow();

    log("Setting up client");
    ClientThread client = new ClientThread(address);
    client.start();
    Thread.sleep(100);

    // Set up initial set of client sockets.
    log("Starting initial client connections");
    client.connectClients(initCount);
    Thread.sleep(500);  // Wait for client connections to arrive

    // Accept all initial client sockets, add to selector and run
    // epoll_ctl.
    log("Accepting initial connections");
    List<SocketChannel> serverChannels1 =
        acceptAndAddAll(serverSelector, server, initCount);
    if (serverChannels1.size() != initCount) {
        throw new Exception("Accepted " + serverChannels1.size() +
                            " instead of " + initCount);
    }
    serverSelector.selectNow();

    // Set up mass set of client sockets.
    log("Requesting mass client connections");
    client.connectClients(massCount);
    Thread.sleep(500);  // Wait for client connections to arrive

    // Accept all mass client sockets, add to selector and do NOT
    // run epoll_ctl.
    log("Accepting mass connections");
    List<SocketChannel> serverChannels2 =
        acceptAndAddAll(serverSelector, server, massCount);
    if (serverChannels2.size() != massCount) {
        throw new Exception("Accepted " + serverChannels2.size() +
                            " instead of " + massCount);
    }

    // Close initial set of sockets.
    log("Closing initial connections");
    closeAll(serverChannels1);

    // Now get the timing of select() call.
    log("Running the final select call");
    long startTime = System.nanoTime();
    serverSelector.selectNow();
    long duration = durationMillis(startTime);
    log("Init count = " + initCount +
        ", mass count = " + massCount +
        ", duration = " + duration + "ms");

    if (duration > maxSelectTime) {
        System.out.println
            ("\n\n\n\n\nFAILURE: The final selectNow() took " +
             duration + "ms " +
             "- seems like O(N^2) bug is still here\n\n");
        System.exit(1);
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:73,代碼來源:LotsOfCancels.java


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