Mercurial > hg > Members > nobuyasu > tightVNCProxy
changeset 53:9250cacee347
MultiThreadTee
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Thu, 07 Jul 2011 22:29:53 +0900 (2011-07-07) |
parents | 6eb7d0c8f11d |
children | a60ec7414931 |
files | src/test/MultiThreadTee.java src/test/MulticastQueue.java |
diffstat | 2 files changed, 16 insertions(+), 9 deletions(-) [+] |
line wrap: on
line diff
--- a/src/test/MultiThreadTee.java Thu Jul 07 21:13:09 2011 +0900 +++ b/src/test/MultiThreadTee.java Thu Jul 07 22:29:53 2011 +0900 @@ -1,17 +1,20 @@ package test; import java.util.LinkedList; +import java.util.concurrent.BlockingQueue; +import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.SynchronousQueue; public class MultiThreadTee { static class Parent extends Thread { - LinkedList<SynchronousQueue<String>> clients = new LinkedList<SynchronousQueue<String>>(); + LinkedList<BlockingQueue<String>> clients = new LinkedList<BlockingQueue<String>>(); - SynchronousQueue<String> accept() { + BlockingQueue<String> accept() { - SynchronousQueue<String> s = new SynchronousQueue<String>(); + // BlockingQueue<String> s = new LinkedBlockingQueue<String>(); + BlockingQueue<String> s = new SynchronousQueue<String>(); clients.add(s); return s; @@ -20,7 +23,7 @@ } void put(String s) throws InterruptedException { - for (SynchronousQueue<String> queue : clients) { + for (BlockingQueue<String> queue : clients) { queue.put(s); } @@ -33,7 +36,7 @@ static class Client extends Thread { Parent p; - private SynchronousQueue<String> queue; + private BlockingQueue<String> queue; @@ -48,8 +51,14 @@ String item; // while(!(item = queue.poll()).equals("") ) { while(true) { - item = queue.poll(); - if(item == null) continue; + try { + item = queue.take(); + } catch (InterruptedException e) { + // TODO Auto-generated catch block + // System.out.println("wating"); + continue; + } + // if(item == null) continue; if(item.equals("")) return; System.out.println(item); }
--- a/src/test/MulticastQueue.java Thu Jul 07 21:13:09 2011 +0900 +++ b/src/test/MulticastQueue.java Thu Jul 07 22:29:53 2011 +0900 @@ -14,7 +14,6 @@ Runnable type2 = new Runnable(){ - @Override public void run() { Client<String> client = queue.newClient(); @@ -34,7 +33,6 @@ Runnable thread = new Runnable(){ - @Override public void run() { Client<String> client = queue.newClient();