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

📄 ioutil.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.core;import java.util.ArrayList;import java.util.Collection;import java.util.Iterator;import java.util.List;import java.util.concurrent.TimeUnit;import org.apache.mina.core.buffer.IoBuffer;import org.apache.mina.core.future.IoFuture;import org.apache.mina.core.future.WriteFuture;import org.apache.mina.core.session.IoSession;/** * A utility class that provides various convenience methods related with * {@link IoSession} and {@link IoFuture}. *  * @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 class IoUtil {        private static final IoSession[] EMPTY_SESSIONS = new IoSession[0];    /**     * Writes the specified {@code message} to the specified {@code sessions}.     * If the specified {@code message} is an {@link IoBuffer}, the buffer is     * automatically duplicated using {@link IoBuffer#duplicate()}.     */    public static List<WriteFuture> broadcast(Object message, Collection<IoSession> sessions) {        List<WriteFuture> answer = new ArrayList<WriteFuture>(sessions.size());        broadcast(message, sessions.iterator(), answer);        return answer;    }    /**     * Writes the specified {@code message} to the specified {@code sessions}.     * If the specified {@code message} is an {@link IoBuffer}, the buffer is     * automatically duplicated using {@link IoBuffer#duplicate()}.     */    public static List<WriteFuture> broadcast(Object message, Iterable<IoSession> sessions) {        List<WriteFuture> answer = new ArrayList<WriteFuture>();        broadcast(message, sessions.iterator(), answer);        return answer;    }        /**     * Writes the specified {@code message} to the specified {@code sessions}.     * If the specified {@code message} is an {@link IoBuffer}, the buffer is     * automatically duplicated using {@link IoBuffer#duplicate()}.     */    public static List<WriteFuture> broadcast(Object message, Iterator<IoSession> sessions) {        List<WriteFuture> answer = new ArrayList<WriteFuture>();        broadcast(message, sessions, answer);        return answer;    }        /**     * Writes the specified {@code message} to the specified {@code sessions}.     * If the specified {@code message} is an {@link IoBuffer}, the buffer is     * automatically duplicated using {@link IoBuffer#duplicate()}.     */    public static List<WriteFuture> broadcast(Object message, IoSession... sessions) {        if (sessions == null) {            sessions = EMPTY_SESSIONS;        }                List<WriteFuture> answer = new ArrayList<WriteFuture>(sessions.length);        if (message instanceof IoBuffer) {            for (IoSession s: sessions) {                answer.add(s.write(((IoBuffer) message).duplicate()));            }        } else {            for (IoSession s: sessions) {                answer.add(s.write(message));            }        }        return answer;    }        private static void broadcast(Object message, Iterator<IoSession> sessions, Collection<WriteFuture> answer) {        if (message instanceof IoBuffer) {            while (sessions.hasNext()) {                IoSession s = sessions.next();                answer.add(s.write(((IoBuffer) message).duplicate()));            }        } else {            while (sessions.hasNext()) {                IoSession s = sessions.next();                answer.add(s.write(message));            }        }    }        public static void await(Iterable<? extends IoFuture> futures) throws InterruptedException {        for (IoFuture f: futures) {            f.await();        }    }        public static void awaitUninterruptably(Iterable<? extends IoFuture> futures) {        for (IoFuture f: futures) {            f.awaitUninterruptibly();        }    }        public static boolean await(Iterable<? extends IoFuture> futures, long timeout, TimeUnit unit) throws InterruptedException {        return await(futures, unit.toMillis(timeout));    }    public static boolean await(Iterable<? extends IoFuture> futures, long timeoutMillis) throws InterruptedException {        return await0(futures, timeoutMillis, true);    }    public static boolean awaitUninterruptibly(Iterable<? extends IoFuture> futures, long timeout, TimeUnit unit) {        return awaitUninterruptibly(futures, unit.toMillis(timeout));    }    public static boolean awaitUninterruptibly(Iterable<? extends IoFuture> futures, long timeoutMillis) {        try {            return await0(futures, timeoutMillis, false);        } catch (InterruptedException e) {            throw new InternalError();        }    }    private static boolean await0(Iterable<? extends IoFuture> futures, long timeoutMillis, boolean interruptable) throws InterruptedException {        long startTime = timeoutMillis <= 0 ? 0 : System.currentTimeMillis();        long waitTime = timeoutMillis;                boolean lastComplete = true;        Iterator<? extends IoFuture> i = futures.iterator();        while (i.hasNext()) {            IoFuture f = i.next();            do {                if (interruptable) {                    lastComplete = f.await(waitTime);                } else {                    lastComplete = f.awaitUninterruptibly(waitTime);                }                                waitTime = timeoutMillis - (System.currentTimeMillis() - startTime);                if (lastComplete || waitTime <= 0) {                    break;                }            } while (!lastComplete);                        if (waitTime <= 0) {                break;            }        }                return lastComplete && !i.hasNext();    }    private IoUtil() {    }}

⌨️ 快捷键说明

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