- Concurrency - Discussion
- Concurrency - Useful Resources
- Concurrency - Quick Guide
- ConcurrentNavigableMap
- Concurrency - ConcurrentMap
- Concurrency - BlockingQueue
- Concurrency - Fork-Join framework
- Concurrency - Futures and Callables
- ScheduledThreadPoolExecutor
- Concurrency - ThreadPoolExecutor
- newSingleThreadExecutor
- newScheduledThreadPool
- Concurrency - newCachedThreadPool
- Concurrency - newFixedThreadPool
- ScheduledExecutorService
- Concurrency - ExecutorService
- Concurrency - Executor
- Concurrency - AtomicReferenceArray
- Concurrency - AtomicLongArray
- Concurrency - AtomicIntegerArray
- Concurrency - AtomicReference
- Concurrency - AtomicBoolean
- Concurrency - AtomicLong
- Concurrency - AtomicInteger
- Concurrency - Condition
- Concurrency - ReadWriteLock
- Concurrency - Lock
- Concurrency - ThreadLocalRandom
- Concurrency - ThreadLocal
- Concurrency - Deadlock
- Concurrency - Synchronization
- Interthread Communication
- Concurrency - Major Operations
- Concurrency - Environment Setup
- Concurrency - Overview
- Concurrency - Home
Selected Reading
- Who is Who
- Computer Glossary
- HR Interview Questions
- Effective Resume Writing
- Questions and Answers
- UPSC IAS Exams Notes
Interthread Communication
If you are aware of interprocess communication then it will be easy for you to understand interthread communication. Interthread communication is important when you develop an apppcation where two or more threads exchange some information.
There are three simple methods and a pttle trick which makes thread communication possible. All the three methods are psted below −
Sr.No. | Method & Description |
---|---|
1 | pubpc void wait() Causes the current thread to wait until another thread invokes the notify(). |
2 | pubpc void notify() Wakes up a single thread that is waiting on this object s monitor. |
3 | pubpc void notifyAll() Wakes up all the threads that called wait( ) on the same object. |
These methods have been implemented as final methods in Object, so they are available in all the classes. All three methods can be called only from within a synchronized context.
Example
This examples shows how two threads can communicate using wait() and notify() method. You can create a complex system using the same concept.
class Chat { boolean flag = false; pubpc synchronized void Question(String msg) { if (flag) { try { wait(); } catch (InterruptedException e) { e.printStackTrace(); } } System.out.println(msg); flag = true; notify(); } pubpc synchronized void Answer(String msg) { if (!flag) { try { wait(); } catch (InterruptedException e) { e.printStackTrace(); } } System.out.println(msg); flag = false; notify(); } } class T1 implements Runnable { Chat m; String[] s1 = { "Hi", "How are you ?", "I am also doing fine!" }; pubpc T1(Chat m1) { this.m = m1; new Thread(this, "Question").start(); } pubpc void run() { for (int i = 0; i < s1.length; i++) { m.Question(s1[i]); } } } class T2 implements Runnable { Chat m; String[] s2 = { "Hi", "I am good, what about you?", "Great!" }; pubpc T2(Chat m2) { this.m = m2; new Thread(this, "Answer").start(); } pubpc void run() { for (int i = 0; i < s2.length; i++) { m.Answer(s2[i]); } } } pubpc class TestThread { pubpc static void main(String[] args) { Chat m = new Chat(); new T1(m); new T2(m); } }
When the above program is compped and executed, it produces the following result −
Output
Hi Hi How are you ? I am good, what about you? I am also doing fine! Great!
Above example has been taken and then modified from [https://stackoverflow.com/questions/2170520/inter-thread-communication-in-java]
Advertisements