当前位置: 首页>>代码示例>>Java>>正文


Java EndOfStreamException类代码示例

本文整理汇总了Java中org.apache.zookeeper.ClientCnxn.EndOfStreamException的典型用法代码示例。如果您正苦于以下问题:Java EndOfStreamException类的具体用法?Java EndOfStreamException怎么用?Java EndOfStreamException使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。


EndOfStreamException类属于org.apache.zookeeper.ClientCnxn包,在下文中一共展示了EndOfStreamException类的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: doTransport

import org.apache.zookeeper.ClientCnxn.EndOfStreamException; //导入依赖的package包/类
@Override
void doTransport(int waitTimeOut,
                 List<Packet> pendingQueue,
                 ClientCnxn cnxn)
        throws IOException, InterruptedException {
    try {
        if (!firstConnect.await(waitTimeOut, TimeUnit.MILLISECONDS)) {
            return;
        }
        Packet head = null;
        if (needSasl.get()) {
            if (!waitSasl.tryAcquire(waitTimeOut, TimeUnit.MILLISECONDS)) {
                return;
            }
        } else {
            if ((head = outgoingQueue.poll(waitTimeOut, TimeUnit.MILLISECONDS)) == null) {
                return;
            }
        }
        // check if being waken up on closing.
        if (!sendThread.getZkState().isAlive()) {
            // adding back the patck to notify of failure in conLossPacket().
            addBack(head);
            return;
        }
        // channel disconnection happened
        if (disconnected.get()) {
            addBack(head);
            throw new EndOfStreamException("channel for sessionid 0x"
                    + Long.toHexString(sessionId)
                    + " is lost");
        }
        if (head != null) {
            doWrite(pendingQueue, head, cnxn);
        }
    } finally {
        updateNow();
    }
}
 
开发者ID:didichuxing2,项目名称:https-github.com-apache-zookeeper,代码行数:40,代码来源:ClientCnxnSocketNetty.java

示例2: doIO

import org.apache.zookeeper.ClientCnxn.EndOfStreamException; //导入依赖的package包/类
/**
 * @return true if a packet was received
 * @throws InterruptedException
 * @throws IOException
 */
boolean doIO(List<Packet> pendingQueue, LinkedList<Packet> outgoingQueue) throws InterruptedException, IOException {
    boolean packetReceived = false;
    SocketChannel sock = (SocketChannel) sockKey.channel();
    if (sock == null) {
        throw new IOException("Socket is null!");
    }
    if (sockKey.isReadable()) {
        int rc = sock.read(incomingBuffer);
        if (rc < 0) {
            throw new EndOfStreamException(
                    "Unable to read additional data from server sessionid 0x"
                            + Long.toHexString(sessionId)
                            + ", likely server has closed socket");
        }
        if (!incomingBuffer.hasRemaining()) {
            incomingBuffer.flip();
            if (incomingBuffer == lenBuffer) {
                recvCount++;
                readLength();
            } else if (!initialized) {
                readConnectResult();
                enableRead();
                if (!outgoingQueue.isEmpty()) {
                    enableWrite();
                }
                lenBuffer.clear();
                incomingBuffer = lenBuffer;
                packetReceived = true;
                initialized = true;
            } else {
                sendThread.readResponse(incomingBuffer);
                lenBuffer.clear();
                incomingBuffer = lenBuffer;
                packetReceived = true;
            }
        }
    }
    if (sockKey.isWritable()) {
        synchronized (outgoingQueue) {
            if (!outgoingQueue.isEmpty()) {
                ByteBuffer pbb = outgoingQueue.getFirst().bb;
                sock.write(pbb);
                if (!pbb.hasRemaining()) {
                    sentCount++;
                    Packet p = outgoingQueue.removeFirst();
                    if (p.requestHeader != null
                            && p.requestHeader.getType() != OpCode.ping
                            && p.requestHeader.getType() != OpCode.auth) {
                        pendingQueue.add(p);
                    }
                }
            }
        }
    }
    if (outgoingQueue.isEmpty()) {
        disableWrite();
    } else {
        enableWrite();
    }
    return packetReceived;
}
 
开发者ID:gerritjvv,项目名称:bigstreams,代码行数:67,代码来源:ClientCnxnSocketNIO.java


注:本文中的org.apache.zookeeper.ClientCnxn.EndOfStreamException类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。