📄 space.java
字号:
/* * jPOS Project [http://jpos.org] * Copyright (C) 2000-2008 Alejandro P. Revilla * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */package org.jpos.space;/** * <p><b>Space</b> uses concepts described in the Linda Coordination Language * that eases the implementation of other jPOS components (such as * Channels, Muxes, etc.), but it is not by any means an attempt to provide * a full implementation.</p> * * <p>jPOS's Space is basically a Map where each entry is a LinkedList * of values that can be used as a BlockingQueue</p> * * <p>One can place entries on a queue by calling Space.out, take them * by calling Space.in and read (without taking) by calling Space.rd</p> * * @author Alejandro Revilla * @version $Revision: 2594 $ $Date: 2008-01-22 14:41:31 -0200 (Tue, 22 Jan 2008) $ * @since 2.0 * @see LeasedReference * @see TransientSpace * @see SpaceError * @see <a href="http://www.cs.yale.edu/Linda/linda-lang.html">The Linda Coordination Language</a> */public interface Space { /** * Write a new entry into the Space * @param key Entry's key * @param value Object value */ public void out (Object key, Object value); /** * Write a new entry into the Space, with an timeout value * @param key Entry's key * @param value Object value * @param timeout timeout value */ public void out (Object key, Object value, long timeout); /** * Take an entry from the space, waiting forever until one exists. * @param key Entry's key * @return value */ public Object in (Object key); /** * Read an entry from the space, waiting forever until one exists. * @param key Entry's key * @return value */ public Object rd (Object key); /** * Take an entry from the space, waiting a limited amount of time * until one exists. * @param key Entry's key * @param timeout millis to wait * @return value or null */ public Object in (Object key, long timeout); /** * Read an entry from the space, waiting a limited amount of time * until one exists. * @param key Entry's key * @param timeout millis to wait * @return value or null */ public Object rd (Object key, long timeout); /** * In probe takes an entry from the space if one exists, * return null otherwise. * @param key Entry's key * @return value or null */ public Object inp (Object key); /** * Read probe reads an entry from the space if one exists, * return null otherwise. * @param key Entry's key * @return value or null */ public Object rdp (Object key); /** * Write a new entry at the head of a queue. * @param key Entry's key * @param value Object value */ public void push (Object key, Object value); /** * Write a new entry at the head of the queue with a timeout value * @param key Entry's key * @param value Object value * @param timeout timeout value */ public void push (Object key, Object value, long timeout);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -