84 lines
2.3 KiB
Java
84 lines
2.3 KiB
Java
// concurrency/ExchangerDemo.java
|
|
// (c)2016 MindView LLC: see Copyright.txt
|
|
// We make no guarantees that this code is fit for any purpose.
|
|
// Visit http://mindviewinc.com/Books/OnJava/ for more book information.
|
|
import java.util.concurrent.*;
|
|
import java.util.*;
|
|
import java.util.function.*;
|
|
import onjava.*;
|
|
|
|
class ExchangerProducer<T> implements Runnable {
|
|
private Supplier<T> generator;
|
|
private Exchanger<List<T>> exchanger;
|
|
private List<T> holder;
|
|
ExchangerProducer(Exchanger<List<T>> exchg,
|
|
Supplier<T> gen, List<T> holder) {
|
|
exchanger = exchg;
|
|
generator = gen;
|
|
this.holder = holder;
|
|
}
|
|
@Override
|
|
public void run() {
|
|
try {
|
|
while(!Thread.interrupted()) {
|
|
for(int i = 0; i < ExchangerDemo.size; i++)
|
|
holder.add(generator.get());
|
|
// Exchange full for empty:
|
|
holder = exchanger.exchange(holder);
|
|
}
|
|
} catch(InterruptedException e) {
|
|
// OK to terminate this way.
|
|
}
|
|
}
|
|
}
|
|
|
|
class ExchangerConsumer<T> implements Runnable {
|
|
private Exchanger<List<T>> exchanger;
|
|
private List<T> holder;
|
|
private volatile T value;
|
|
ExchangerConsumer(Exchanger<List<T>> ex, List<T> holder){
|
|
exchanger = ex;
|
|
this.holder = holder;
|
|
}
|
|
@Override
|
|
public void run() {
|
|
try {
|
|
while(!Thread.interrupted()) {
|
|
holder = exchanger.exchange(holder);
|
|
for(T x : holder) {
|
|
value = x; // Fetch out value
|
|
holder.remove(x); // OK for CopyOnWriteArrayList
|
|
}
|
|
}
|
|
} catch(InterruptedException e) {
|
|
// OK to terminate this way.
|
|
}
|
|
System.out.println("Final value: " + value);
|
|
}
|
|
}
|
|
|
|
public class ExchangerDemo {
|
|
static int size = 10;
|
|
static int delay = 5; // Seconds
|
|
public static void main(String[] args) throws Exception {
|
|
if(args.length > 0)
|
|
size = new Integer(args[0]);
|
|
if(args.length > 1)
|
|
delay = new Integer(args[1]);
|
|
ExecutorService exec = Executors.newCachedThreadPool();
|
|
Exchanger<List<Fat>> xc = new Exchanger<>();
|
|
List<Fat>
|
|
producerList = new CopyOnWriteArrayList<>(),
|
|
consumerList = new CopyOnWriteArrayList<>();
|
|
exec.execute(new ExchangerProducer<>(xc,
|
|
BasicSupplier.create(Fat.class), producerList));
|
|
exec.execute(
|
|
new ExchangerConsumer<>(xc,consumerList));
|
|
TimeUnit.SECONDS.sleep(delay);
|
|
exec.shutdownNow();
|
|
}
|
|
}
|
|
/* Output:
|
|
Final value: Fat id: 18859
|
|
*/
|