add monitor design pattern (#1640)
* add monitor design pattern . * add extra line and change compiler version to 11 in pom.xml. * encapsulate getBalance method . * update puml file . * export uml as png . * duplicate codes eliminated . * update tag * change the format of pom.xml * using logger to print * change AtomicRefrence to type inference var * explanations added ! * Update monitor/README.md Co-authored-by: Ilkka Seppälä <iluwatar@users.noreply.github.com> * Update monitor/README.md Co-authored-by: Ilkka Seppälä <iluwatar@users.noreply.github.com> * Update monitor/src/main/java/com/iluwatar/monitor/Main.java Co-authored-by: Ilkka Seppälä <iluwatar@users.noreply.github.com> * Update monitor/src/main/java/com/iluwatar/monitor/Main.java Co-authored-by: Ilkka Seppälä <iluwatar@users.noreply.github.com> * Update monitor/src/main/java/com/iluwatar/monitor/Main.java Co-authored-by: Ilkka Seppälä <iluwatar@users.noreply.github.com> * Update monitor/src/main/java/com/iluwatar/monitor/Main.java Co-authored-by: Ilkka Seppälä <iluwatar@users.noreply.github.com> * e.printStackTrace have changed to logger to prints standard output (STD OUT) . * add programmatic example . * Delete mvnw * mvnw.cmd deleted . * added mvnw from master * AddUnitTest * Add language to readme.md Co-authored-by: Subhrodip Mohanta <subhrodipmohanta@gmail.com> Co-authored-by: Ilkka Seppälä <iluwatar@users.noreply.github.com> Co-authored-by: Subhrodip Mohanta <subhromo@cisco.com> Co-authored-by: Subhrodip Mohanta <contact@subho.xyz>
This commit is contained in:
71
monitor/README.md
Normal file
71
monitor/README.md
Normal file
@ -0,0 +1,71 @@
|
||||
---
|
||||
layout: pattern
|
||||
title: Monitor
|
||||
folder: monitor
|
||||
permalink: /patterns/monitor/
|
||||
categories: Concurrency
|
||||
language: en
|
||||
tags:
|
||||
- Performance
|
||||
---
|
||||
|
||||
## Intent
|
||||
Monitor pattern is used to create thread-safe objects and prevent conflicts between threads in concurrent applications.
|
||||
|
||||
## Explanation
|
||||
|
||||
In plain words
|
||||
|
||||
> Monitor pattern is used to enforce single-threaded access to data. Only one thread at a time is allowed to execute code within the monitor object.
|
||||
|
||||
Wikipedia says
|
||||
|
||||
> In concurrent programming (also known as parallel programming), a monitor is a synchronization construct that allows threads to have both mutual exclusion and the ability to wait (block) for a certain condition to become false. Monitors also have a mechanism for signaling other threads that their condition has been met.
|
||||
|
||||
**Programmatic Examples**
|
||||
|
||||
Consider there is a bank that transfers money from an account to another account with transfer method . it is `synchronized` mean just one thread can access to this method because if many threads access to it and transfer money from an account to another account in same time balance changed !
|
||||
|
||||
```
|
||||
class Bank {
|
||||
|
||||
private int[] accounts;
|
||||
Logger logger;
|
||||
|
||||
public Bank(int accountNum, int baseAmount, Logger logger) {
|
||||
this.logger = logger;
|
||||
accounts = new int[accountNum];
|
||||
Arrays.fill(accounts, baseAmount);
|
||||
}
|
||||
|
||||
public synchronized void transfer(int accountA, int accountB, int amount) {
|
||||
if (accounts[accountA] >= amount) {
|
||||
accounts[accountB] += amount;
|
||||
accounts[accountA] -= amount;
|
||||
logger.info("Transferred from account :" + accountA + " to account :" + accountB + " , amount :" + amount + " . balance :" + getBalance());
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
getBalance always return total amount and the total amount should be same after each transfers
|
||||
|
||||
```
|
||||
private synchronized int getBalance() {
|
||||
int balance = 0;
|
||||
for (int account : accounts) {
|
||||
balance += account;
|
||||
}
|
||||
return balance;
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
## Class diagram
|
||||

|
||||
|
||||
## Applicability
|
||||
Use the Monitor pattern when
|
||||
|
||||
* we have a shared resource and there is critical section .
|
||||
* you want to create thread-safe objects .
|
||||
* you want to achieve mutual exclusion in high level programming language .
|
Reference in New Issue
Block a user