• August 30, 2014
  • Core Java
  • Comments Off on Inter-thread communication in java

Inter-thread communication in java

Inter-thread communication:

Inter-thread communication is a process in which a thread is paused running in its critical region and another thread is allowed to enter (or lock) in the same critical region to be executed. i.e. synchronized threads communicate with each other.

Below object class methods are used for Inter-thread communication process:

1. wait(): this method instructs the current thread to release the monitor held by it and to get suspended until some other threads sends a notification from the same monitor.

Syntax: public void wait() throws InterruptedException. 

2. notify(): this method is used to send the notification to the thread that is suspended by the wait() method.

Syntax: public void notify().

3. notifyAll(): this method is used to send the notification to all the threads that are suspended by wait() method.

Syntax: public void notifyAll().

Producer-consumer problem to understand Inter-thread communication.

Example:

ProducerConsumerExample.java

/**
 * This program is used to show the inter thread communication. 
 * @author javawithease
 */
class Buffer{
	int a;
	boolean produced = false;
 
	public synchronized void produce(int x){
		if(produced){
			System.out.println("Producer is waiting...");
			try{
				wait();
			}catch(Exception e){
				System.out.println(e);
			}
		}
		a=x;
		System.out.println("Product" + a + " is produced.");
		produced = true;
		notify();		
	}
 
	public synchronized void consume(){
		if(!produced){
			System.out.println("Consumer is waiting...");
			try{
				wait();
			}catch(Exception e){
				System.out.println(e);
			}
		}
		System.out.println("Product" + a + " is consumed.");
		produced = false;
		notify();
	}
}
 
class Producer extends Thread{
	Buffer b;
	public Producer(Buffer b){
		this.b = b;
	}
 
	public void run(){
		System.out.println("Producer start producing...");
		for(int i = 1; i <= 10; i++){
			b.produce(i);
		}
	}
}
 
class Consumer extends Thread{
	Buffer b;
	public Consumer(Buffer b){
		this.b = b;
	}
 
	public void run(){
		System.out.println("Consumer start consuming...");
		for(int i = 1; i <= 10; i++){
			b.consume(); 
		}
	}
}
 
public class ProducerConsumerExample {
	public static void main(String args[]){
		//Create Buffer object.
		Buffer b = new Buffer();
 
		//creating producer thread.
		Producer p = new Producer(b);
 
		//creating consumer thread.
		Consumer c = new Consumer(b);
 
		//starting threads.
		p.start();
		c.start();
	}
}

Output:

Consumer start consuming...
Producer start producing...
Consumer is waiting...
Product1 is produced.
Producer is waiting...
Product1 is consumed.
Consumer is waiting...
Product2 is produced.
Producer is waiting...
Product2 is consumed.
Consumer is waiting...
Product3 is produced.
Producer is waiting...
Product3 is consumed.
Consumer is waiting...
Product4 is produced.
Producer is waiting...
Product4 is consumed.
Consumer is waiting...
Product5 is produced.
Producer is waiting...
Product5 is consumed.
Consumer is waiting...
Product6 is produced.
Producer is waiting...
Product6 is consumed.
Consumer is waiting...
Product7 is produced.
Producer is waiting...
Product7 is consumed.
Consumer is waiting...
Product8 is produced.
Producer is waiting...
Product8 is consumed.
Consumer is waiting...
Product9 is produced.
Producer is waiting...
Product9 is consumed.
Consumer is waiting...
Product10 is produced.
Product10 is consumed.

Download this example.
 
Next Topic: Synchronization in java with example.
Previous Topic: Starvation in java with example.

Related Topics:

Multithreading in java.
Thread life cycle in java.
Way of creating thread in java.
Commonly used methods of Thread class.
Thread scheduling in java with example.
Thread priority in java with example.
Naming a thread in java with example.
Joining a thread in java with example.
Daemon thread in java with example.
Can we start a thread twice?
Can we call run method directly?
Difference between Thread.yield() and Thread.sleep() methods.
Deadlock in java with example.
Starvation in java with example.
Inter-thread communication in java with example.
Synchronization in java with example.
Synchronized method in java with example.
Static synchronization in java with example.
Synchronized block in java with example.

 


Comments are closed.