Mega Code Archive

 
Categories / Java / Threads
 

An implementation of a producer and consumer that use semaphores to control synchronization

import java.util.concurrent.Semaphore; class Queue {   int value;   static Semaphore semCon = new Semaphore(0);   static Semaphore semProd = new Semaphore(1);   void get() {     try {       semCon.acquire();     } catch (InterruptedException e) {       System.out.println("InterruptedException caught");     }     System.out.println("Got: " + value);     semProd.release();   }   void put(int n) {     try {       semProd.acquire();     } catch (InterruptedException e) {       System.out.println("InterruptedException caught");     }     this.value = n;     System.out.println("Put: " + n);     semCon.release();   } } class Producer implements Runnable {   Queue q;   Producer(Queue q) {     this.q = q;     new Thread(this, "Producer").start();   }   public void run() {     for (int i = 0; i < 20; i++)       q.put(i);   } } class Consumer implements Runnable {   Queue q;   Consumer(Queue q) {     this.q = q;     new Thread(this, "Consumer").start();   }   public void run() {     for (int i = 0; i < 20; i++)       q.get();   } } public class ProdCon {   public static void main(String args[]) {     Queue q = new Queue();     new Consumer(q);     new Producer(q);   } }