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


Java SelectionKey類代碼示例

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


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

示例1: process

import java.nio.channels.SelectionKey; //導入依賴的package包/類
private void process() {
    Iterator<SelectionKey> it = selector.selectedKeys().iterator();
    while (it.hasNext()) {
        SelectionKey key = it.next();
        it.remove();
        if (!key.isValid()) {
            continue;
        }
        ChannelHandler handler = (ChannelHandler) key.attachment();
        if (key.isAcceptable()) {
            handler.accept(key);
        } else if (key.isConnectable()) {
            handler.connect(key);
        } else if (key.isReadable()) {
            handler.read(key);
        } else if (key.isWritable()) {
            handler.write(key);
        }
    }
}
 
開發者ID:xiaoma20082008,項目名稱:mysql-protocol,代碼行數:21,代碼來源:Multiplexer.java

示例2: doRead

import java.nio.channels.SelectionKey; //導入依賴的package包/類
void doRead(SelectionKey key) throws InterruptedException {
  int count = 0;
  Connection c = (Connection)key.attachment();
  if (c == null) {
    return;  
  }
  c.setLastContact(Time.now());
  
  try {
    count = c.readAndProcess();
  } catch (InterruptedException ieo) {
    LOG.info(Thread.currentThread().getName() + ": readAndProcess caught InterruptedException", ieo);
    throw ieo;
  } catch (Exception e) {
    // a WrappedRpcServerException is an exception that has been sent
    // to the client, so the stacktrace is unnecessary; any other
    // exceptions are unexpected internal server errors and thus the
    // stacktrace should be logged
    LOG.info(Thread.currentThread().getName() + ": readAndProcess from client " +
        c.getHostAddress() + " threw exception [" + e + "]",
        (e instanceof WrappedRpcServerException) ? null : e);
    count = -1; //so that the (count < 0) block is executed
  }
  if (count < 0) {
    closeConnection(c);
    c = null;
  }
  else {
    c.setLastContact(Time.now());
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:32,代碼來源:Server.java

示例3: timeoutExceptionString

import java.nio.channels.SelectionKey; //導入依賴的package包/類
private static String timeoutExceptionString(SelectableChannel channel,
                                             long timeout, int ops) {
  
  String waitingFor;
  switch(ops) {
  
  case SelectionKey.OP_READ :
    waitingFor = "read"; break;
    
  case SelectionKey.OP_WRITE :
    waitingFor = "write"; break;      
    
  case SelectionKey.OP_CONNECT :
    waitingFor = "connect"; break;
    
  default :
    waitingFor = "" + ops;  
  }
  
  return timeout + " millis timeout while " +
         "waiting for channel to be ready for " + 
         waitingFor + ". ch : " + channel;    
}
 
開發者ID:spafka,項目名稱:spark_deep,代碼行數:24,代碼來源:SocketIOWithTimeout.java

示例4: sendPacket

import java.nio.channels.SelectionKey; //導入依賴的package包/類
public final void sendPacket(final SendablePacket<T> sp)
 {
     sp._client = _client;

     if (_pendingClose)
return;
     
     synchronized (getSendQueue())
     {
     	_sendQueue.addLast(sp);
     }

     if (!_sendQueue.isEmpty())
     {
         try
         {
             _selectionKey.interestOps(_selectionKey.interestOps() | SelectionKey.OP_WRITE);
         }
         catch (CancelledKeyException e)
         {
             // ignore
         }
     }
 }
 
開發者ID:L2jBrasil,項目名稱:L2jBrasil,代碼行數:25,代碼來源:MMOConnection.java

示例5: processAcceptedConnections

import java.nio.channels.SelectionKey; //導入依賴的package包/類
/**
 * Iterate over the queue of accepted connections that have been
 * assigned to this thread but not yet placed on the selector.
 */
private void processAcceptedConnections() {
    SocketChannel accepted;
    while (!stopped && (accepted = acceptedQueue.poll()) != null) {
        SelectionKey key = null;
        try {
            key = accepted.register(selector, SelectionKey.OP_READ);
            NIOServerCnxn cnxn = createConnection(accepted, key, this);
            key.attach(cnxn);
            addCnxn(cnxn);
        } catch (IOException e) {
            // register, createConnection
            cleanupSelectionKey(key);
            fastCloseSock(accepted);
        }
    }
}
 
開發者ID:didichuxing2,項目名稱:https-github.com-apache-zookeeper,代碼行數:21,代碼來源:NIOServerCnxnFactory.java

示例6: run

import java.nio.channels.SelectionKey; //導入依賴的package包/類
@Override
public void run() {
    try {
        while (true) {
            selector.select();
            Set<SelectionKey> keys = selector.selectedKeys();
            Iterator<SelectionKey> i = keys.iterator();
            if (i.hasNext()) {
                SelectionKey key = i.next();
                keys.remove(key);
                handleEvent(key);
            }
        }
    } catch (IOException e) {
        e.printStackTrace();
    }
}
 
開發者ID:ZhangJiupeng,項目名稱:AgentX,代碼行數:18,代碼來源:SocketTunnel.java

示例7: enqueue

import java.nio.channels.SelectionKey; //導入依賴的package包/類
/**
 * Queue a FastSerializable object for writing. This is 2nd best way to serialize and queue messages.
 * The expected message size is used to size the initial allocation for the FastSerializer.
 * Because FastSerializer is used to serialize the object there is some over head incurred
 * when the FastSerializer has to check if it needs to grow, but the cost is pretty minor compared
 * to the cost of actually growing the FastSerializer.
 * @param f
 */
@Override
public boolean enqueue(final FastSerializable f, final int expectedSize) {
    synchronized (this) {
        if (m_isShutdown) {
            return false;
        }
        updateLastPendingWriteTimeAndQueueBackpressure();
        m_queuedWrites.offer(new DeferredSerialization() {
            @Override
            public BBContainer serialize(final DBBPool pool) throws IOException {
                final FastSerializer fs = new FastSerializer(pool, expectedSize);
                return fs.writeObjectForMessaging(f);
            }

            @Override
            public void cancel() {}
        });
        m_port.setInterests( SelectionKey.OP_WRITE, 0);
    }
    return true;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:30,代碼來源:NIOWriteStream.java

示例8: connect

import java.nio.channels.SelectionKey; //導入依賴的package包/類
private void connect(Selector selector) {
	AbstractConnection c = null;
	while ((c = connectQueue.poll()) != null) {
		try {
			SocketChannel channel = (SocketChannel) c.getChannel();
			// 注冊 OP_CONNECT(建立連接) 監聽與後端連接是否真正建立  // 監聽到之後是圖-MySql第3步,(TCP連接建立)
			channel.register(selector, SelectionKey.OP_CONNECT, c);
			// 主動連接  阻塞或者非阻塞  // 圖-MySql第1步,(TCP連接請求)
			channel.connect(new InetSocketAddress(c.host, c.port));

		} catch (Exception e) {
			LOGGER.error("error:",e);
			c.close(e.toString());
		}
	}
}
 
開發者ID:huang-up,項目名稱:mycat-src-1.6.1-RELEASE,代碼行數:17,代碼來源:NIOConnector.java

示例9: connectMaster

import java.nio.channels.SelectionKey; //導入依賴的package包/類
private boolean connectMaster() throws ClosedChannelException {
    if (null == socketChannel) {
        String addr = this.masterAddress.get();
        if (addr != null) {

            SocketAddress socketAddress = RemotingUtil.string2SocketAddress(addr);
            if (socketAddress != null) {
                this.socketChannel = RemotingUtil.connect(socketAddress);
                if (this.socketChannel != null) {
                    this.socketChannel.register(this.selector, SelectionKey.OP_READ);
                }
            }
        }

        // 每次連接時,要重新拿到最大的Offset
        this.currentReportedOffset = HAService.this.defaultMessageStore.getMaxPhyOffset();

        this.lastWriteTimestamp = System.currentTimeMillis();
    }

    return this.socketChannel != null;
}
 
開發者ID:lirenzuo,項目名稱:rocketmq-rocketmq-all-4.1.0-incubating,代碼行數:23,代碼來源:HAService.java

示例10: onReadable

import java.nio.channels.SelectionKey; //導入依賴的package包/類
public void onReadable(SelectionKey key){
	try {
		ByteBuffer buffer=GL_BUFFER;
		buffer.clear();
		int bytesRead=m_InnerChannel.read(buffer);
		if(bytesRead>0){
			buffer.flip();
			afterReceived(buffer);//先讓子類處理,例如解密數據。
			if(isTunnelEstablished()&&buffer.hasRemaining()){//將讀到的數據,轉發給兄弟。
				m_BrotherTunnel.beforeSend(buffer);//發送之前,先讓子類處理,例如做加密等。
				if(!m_BrotherTunnel.write(buffer,true)){
					key.cancel();//兄弟吃不消,就取消讀取事件。
					if(ProxyConfig.IS_DEBUG)
						System.out.printf("%s can not read more.\n", m_ServerEP);
				}
			} 
		}else if(bytesRead<0) {
			this.dispose();//連接已關閉,釋放資源。
		}
	} catch (Exception e) {
		e.printStackTrace();
		this.dispose();
	}
}
 
開發者ID:w22ee,項目名稱:onekey-proxy-android,代碼行數:25,代碼來源:Tunnel.java

示例11: testInvokeCallbacks

import java.nio.channels.SelectionKey; //導入依賴的package包/類
public void testInvokeCallbacks() throws InterruptedException{
    MockSelector selector = new MockSelector();
    VoltNetwork vn = new VoltNetwork(selector);               // network with fake selector
    MockVoltPort vp = new MockVoltPort(vn, new MockInputHandler());             // implement abstract run()
    MockSelectionKey selectionKey = new MockSelectionKey();   // fake selection key

    // glue the key, the selector and the port together.
    selectionKey.interestOps(SelectionKey.OP_WRITE);
    selector.setFakeKey(selectionKey);
    vp.m_selectionKey = selectionKey;
    selectionKey.attach(vp);
    selectionKey.readyOps(SelectionKey.OP_WRITE);

    // invoke call backs and see that the volt port has the expected
    // selected operations.
    vn.invokeCallbacks();
    assertEquals(SelectionKey.OP_WRITE, vp.readyOps());

    // and another time through, should have the new interests selected
    vp.setInterests(SelectionKey.OP_ACCEPT, 0);
    selectionKey.readyOps(SelectionKey.OP_ACCEPT);
    vn.installInterests();
    vn.invokeCallbacks();
    vn.shutdown();
    assertEquals(SelectionKey.OP_ACCEPT, vp.readyOps());
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:27,代碼來源:VoltNetworkTest.java

示例12: connect

import java.nio.channels.SelectionKey; //導入依賴的package包/類
/**
 * Finishes the connection process for the given connection
 *
 * @param p_key
 *         the selection key
 */
public void connect(final SelectionKey p_key) throws NetworkException {
    if (getPipeOut().getChannel().isConnectionPending()) {
        try {
            if (getPipeOut().getChannel().finishConnect()) {
                connected(p_key);
            } else {
                // #if LOGGER >= ERROR
                LOGGER.error("Connection could not be finished: %s", this);
                // #endif /* LOGGER >= ERROR */
            }
        } catch (final IOException ignore) {
            abortConnectionCreation();
        }
    } else {
        // #if LOGGER >= WARN
        LOGGER.warn("Connection is not pending, connect aborted: %s", this);
        // #endif /* LOGGER >= WARN */
    }
}
 
開發者ID:hhu-bsinfo,項目名稱:dxram,代碼行數:26,代碼來源:NIOConnection.java

示例13: main

import java.nio.channels.SelectionKey; //導入依賴的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

示例14: close

import java.nio.channels.SelectionKey; //導入依賴的package包/類
@Override
protected void close(DatagramChannel handle) throws Exception {
    SelectionKey key = handle.keyFor(selector);

    if (key != null) {
        key.cancel();
    }

    handle.disconnect();
    handle.close();
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:12,代碼來源:NioDatagramAcceptor.java

示例15: Client

import java.nio.channels.SelectionKey; //導入依賴的package包/類
public Client() throws IOException {
	// 同樣的,注冊鬧鍾.
	this.selector = Selector.open();

	// 連接遠程server
	socketChannel = SocketChannel.open();
	// 如果快速的建立了連接,返回true.如果沒有建立,則返回false,並在連接後出發Connect事件.
	Boolean isConnected = socketChannel.connect(new InetSocketAddress("localhost", 3562));
	socketChannel.configureBlocking(false);
	SelectionKey key = socketChannel.register(selector, SelectionKey.OP_READ);

	if (isConnected) {
		this.sendFirstMsg();
	} else {
		// 如果連接還在嘗試中,則注冊connect事件的監聽. connect成功以後會出發connect事件.
		key.interestOps(SelectionKey.OP_CONNECT);
	}
}
 
開發者ID:minilynn,項目名稱:samplecode,代碼行數:19,代碼來源:Client.java


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