⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 abstractstreamwritefilter.java

📁 mina是以Java实现的一个开源的网络程序框架
💻 JAVA
字号:
/* *  Licensed to the Apache Software Foundation (ASF) under one *  or more contributor license agreements.  See the NOTICE file *  distributed with this work for additional information *  regarding copyright ownership.  The ASF licenses this file *  to you under the Apache License, Version 2.0 (the *  "License"); you may not use this file except in compliance *  with the License.  You may obtain a copy of the License at * *    http://www.apache.org/licenses/LICENSE-2.0 * *  Unless required by applicable law or agreed to in writing, *  software distributed under the License is distributed on an *  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY *  KIND, either express or implied.  See the License for the *  specific language governing permissions and limitations *  under the License. * */package org.apache.mina.filter.stream;import java.io.IOException;import java.util.Queue;import org.apache.mina.core.buffer.IoBuffer;import org.apache.mina.core.filterchain.IoFilterAdapter;import org.apache.mina.core.filterchain.IoFilterChain;import org.apache.mina.core.session.AttributeKey;import org.apache.mina.core.session.IoSession;import org.apache.mina.core.write.DefaultWriteRequest;import org.apache.mina.core.write.WriteRequest;import org.apache.mina.util.CircularQueue;/** * TODO Add documentation *  * @author The Apache MINA Project (dev@mina.apache.org) * @version $Rev: 671827 $, $Date: 2008-06-26 10:49:48 +0200 (Thu, 26 Jun 2008) $ */public abstract class AbstractStreamWriteFilter<T> extends IoFilterAdapter {    /**     * The default buffer size this filter uses for writing.     */    public static final int DEFAULT_STREAM_BUFFER_SIZE = 4096;    /**     * The attribute name used when binding the streaming object to the session.     */    protected final AttributeKey CURRENT_STREAM = new AttributeKey(getClass(), "stream");    protected final AttributeKey WRITE_REQUEST_QUEUE = new AttributeKey(getClass(), "queue");    protected final AttributeKey CURRENT_WRITE_REQUEST = new AttributeKey(getClass(), "writeRequest");    private int writeBufferSize = DEFAULT_STREAM_BUFFER_SIZE;    @Override    public void onPreAdd(IoFilterChain parent, String name,            NextFilter nextFilter) throws Exception {        Class<? extends IoFilterAdapter> clazz = getClass();		if (parent.contains(clazz)) {            throw new IllegalStateException(                    "Only one " + clazz.getName() + " is permitted.");        }    }    @Override    public void filterWrite(NextFilter nextFilter, IoSession session,                            WriteRequest writeRequest) throws Exception {        // If we're already processing a stream we need to queue the WriteRequest.        if (session.getAttribute(CURRENT_STREAM) != null) {            Queue<WriteRequest> queue = getWriteRequestQueue(session);            if (queue == null) {                queue = new CircularQueue<WriteRequest>();                session.setAttribute(WRITE_REQUEST_QUEUE, queue);            }            queue.add(writeRequest);            return;        }        Object message = writeRequest.getMessage();        if (getMessageClass().isInstance(message)) {        	T stream = getMessageClass().cast(message);            IoBuffer buffer = getNextBuffer(stream);            if (buffer == null) {                // End of stream reached.                writeRequest.getFuture().setWritten();                nextFilter.messageSent(session, writeRequest);            } else {                session.setAttribute(CURRENT_STREAM, message);                session.setAttribute(CURRENT_WRITE_REQUEST, writeRequest);                nextFilter.filterWrite(session, new DefaultWriteRequest(                        buffer));            }        } else {            nextFilter.filterWrite(session, writeRequest);        }    }        abstract protected Class<T> getMessageClass();    @SuppressWarnings("unchecked")    private Queue<WriteRequest> getWriteRequestQueue(IoSession session) {        return (Queue<WriteRequest>) session.getAttribute(WRITE_REQUEST_QUEUE);    }    @SuppressWarnings("unchecked")    private Queue<WriteRequest> removeWriteRequestQueue(IoSession session) {        return (Queue<WriteRequest>) session.removeAttribute(WRITE_REQUEST_QUEUE);    }        @Override    public void messageSent(NextFilter nextFilter, IoSession session,                            WriteRequest writeRequest) throws Exception {        T stream = getMessageClass().cast(session.getAttribute(CURRENT_STREAM));        if (stream == null) {            nextFilter.messageSent(session, writeRequest);        } else {            IoBuffer buffer = getNextBuffer(stream);            if (buffer == null) {                // End of stream reached.                session.removeAttribute(CURRENT_STREAM);                WriteRequest currentWriteRequest = (WriteRequest) session                        .removeAttribute(CURRENT_WRITE_REQUEST);                // Write queued WriteRequests.                Queue<WriteRequest> queue = removeWriteRequestQueue(session);                if (queue != null) {                    WriteRequest wr = queue.poll();                    while (wr != null) {                        filterWrite(nextFilter, session, wr);                        wr = queue.poll();                    }                }                currentWriteRequest.getFuture().setWritten();                nextFilter.messageSent(session, currentWriteRequest);            } else {                nextFilter.filterWrite(session, new DefaultWriteRequest(                        buffer));            }        }    }    /**     * Returns the size of the write buffer in bytes. Data will be read from the     * stream in chunks of this size and then written to the next filter.     *     * @return the write buffer size.     */    public int getWriteBufferSize() {        return writeBufferSize;    }    /**     * Sets the size of the write buffer in bytes. Data will be read from the     * stream in chunks of this size and then written to the next filter.     *     * @throws IllegalArgumentException if the specified size is &lt; 1.     */    public void setWriteBufferSize(int writeBufferSize) {        if (writeBufferSize < 1) {            throw new IllegalArgumentException(                    "writeBufferSize must be at least 1");        }        this.writeBufferSize = writeBufferSize;    }    abstract protected IoBuffer getNextBuffer(T message) throws IOException;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -