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();