Mercurial > hg > Members > you > TreeVNC
view src/treeVnc/MulticastQueue.java @ 62:b2492abdae2a Version1.0 tip
Added tag TreeVNC_version1.0 for changeset 318ec7415073
author | Taninari YU <you@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 12 Aug 2012 22:13:39 +0900 |
parents | 578ea14c95e9 |
children |
line wrap: on
line source
package treeVnc; import java.util.concurrent.CountDownLatch; public class MulticastQueue<T> { Node<T> tail; public MulticastQueue() { tail = new Node<T>(null); } public synchronized void put(T item) { Node<T> next = new Node<T>(item); tail.set(next); tail = next; } public Client<T> newClient() { return new Client<T>(tail); } static class Client<T> { Node<T> node; Client(Node<T> tail) { node = tail; } synchronized public T poll() { Node<T> next = null; T item = null; do { try { next = node.next(); }catch(InterruptedException _e){ continue; } // item = node.getItem(); item = next.getItem(); node = next; } while ( item == null); return item; } } static class Node<T> { private T item; private Node<T> next; private CountDownLatch latch; public Node(T item) { this.item = item; this.next = null; latch = new CountDownLatch(1); } synchronized public T getItem() { return item; } public void set(Node<T> next) { this.next = next; latch.countDown(); } public Node<T> next() throws InterruptedException { latch.await(); return next; } synchronized public void clear() { item = null; } } }