Synchronized
2527 ワード
import java.util.*;
import java.util.concurrent.*;
class Task
{
private LinkedList<Integer> list = new LinkedList<Integer>();
private static int num=0;
public synchronized void take(){
while(num<=0){
try{
super.wait() ;
}catch(InterruptedException e){
e.printStackTrace() ;
}
}
num--;
int a=list.remove(0);
System.out.println("after "+Thread.currentThread().getName()+" get="+a+" current size="+num);
super.notifyAll();//
}
public synchronized void put(int a){
while(num>=10){
try{
super.wait() ;
}catch(InterruptedException e){
e.printStackTrace() ;
}
}
num++;
list.add(a);
System.out.println("after "+Thread.currentThread().getName()+" put="+a+" current size="+num);
super.notifyAll();//
}
};
class PutThread implements Runnable
{
private Task task;
private final CyclicBarrier cb;
public PutThread(Task task,CyclicBarrier cb)
{
this.task=task;
this.cb=cb;
}
public void run()
{
this.task.put(1);
try
{
cb.await();
}
catch (Exception e)
{
}
}
}
class TakeThread implements Runnable
{
private Task task;
private final CyclicBarrier cb;
public TakeThread(Task task,CyclicBarrier cb)
{
this.task=task;
this.cb=cb;
}
public void run()
{
this.task.take();
try
{
cb.await();
}
catch (Exception e)
{
}
}
}
public class TestSyn
{
public static void main(String [] args)
{
long start=(new Date()).getTime();
Task t=new Task();
final long begin=(new Date()).getTime();
CyclicBarrier cb =new CyclicBarrier(20000,new Runnable(){
public void run()
{
long end=(new Date()).getTime();
System.out.println(end-begin);
}
});
for(int i=0;i<10000;i++)
{
new Thread(new PutThread(t,cb)).start();
}
for(int j=0;j<10000;j++)
{
new Thread(new TakeThread(t,cb)).start();
}
}
}
前にlockでマルチスレッドを実現する文章を送ったことがありますが、synchronizedで実現した文章で、読者は自分で許可して、速度を比較することができます.