 
- OS - Home
- OS - Needs
- OS - Overview
- OS - History
- OS - Components
- OS - Structure
- OS - Architecture
- OS - Services
- OS - Properties
- OS - TAT & WAT
- OS Processes
- OS - Processes
- OS - Process Scheduling
- OS - Scheduling Algorithms
- FCFS Scheduling Algorithm
- SJF Scheduling Algorithm
- Round Robin Scheduling Algorithms
- HRRN Scheduling Algorithms
- Priority Scheduling Algorithms
- Multilevel Queue Scheduling
- Context Switching
- Operations on Processes
- Lottery Process Scheduling
- Predicting Burst Time SJF Scheduling
- Race Condition Vulnerability
- Critical Section Synchronization
- Mutual Exclusion Synchronization
- Process Control Block
- Inter Process Communication
- Preemptive and Non-Preemptive Scheduling
- Operating System - Deadlock
- Introduction to Deadlock in Operating System
- Conditions for Deadlock in Operating System
- OS Synchronization
- Operating System - Process Synchronization
- Operating System - Critical Section
- Operating System - Semaphores
- Operating System - Counting Semaphores
- Operating System - Mutex
- Operating System - Turn Variable in Process Synchronization
- Operating System - Bounded Buffer Problem
- Operating System - Reader Writer Locks in Process Synchronization
- Operating System - Test Set Lock in Process Synchronization
- Operating System - Peterson Solution in Process Synchronization
- Operating System - Monitors in Process Synchronization
- Operating System - Sleep and Wake in Process Synchronization
- OS Memory Management
- OS - Memory Management
- OS - Virtual Memory
- OS - Paging
- OS - Demand Paging
- OS Storage Management
- File Systems in Operating System
- Linked Index Allocation in Operating System
- Indexed Allocation in Operating System
- Structures of Directory in Operating System
- File Attributes in Operating System
- Operating System - Page Replacement
- Operating Systems - Thrashing
- Optimal Page Replacement Algorithm
- Operating System - Types
- Types of Operating System
- Batch Processing Operating System
- Multiprocessing Operating System
- Hybrid Operating System
- Monolithic Operating System
- Zephyr Operating System
- Nix Operating System
- Blackberry Operating System
- Garuda Operating System
- Tails Operating System
- Clustered Operating System
- Haiku Operating System
- AIX Operating System
- Solus Operating system
- Tizen Operating System
- Bharat Operating System
- Fire Operating System
- Bliss Operating System
- VxWorks Operating System
- Embedded Operating System
- Single User Operating System
- OS Miscellaneous
- OS - Multi-threading
- OS - I/O Hardware
- OS - I/O Software
- OS - Security
- OS - Linux
- OS Useful Resources
- OS - Quick Guide
- OS - Useful Resources
- OS - Discussion
Operating System - Monitors in Process Synchronization
Monitors in Process Synchronization
Monitors are a synchronization tool used in process synchronization to manage access to shared resources and coordinate the actions of multiple threads or processes. Compared to low-level primitives like locks or semaphores, they provide a higher-level abstraction for handling concurrency. Let's explore what monitors are, why they are used, and how they are applied in process synchronization −
What are Monitors?
A monitor is a synchronization technique that combines operations and data structures into a single entity. It includes operations that can be performed on shared resources. By allowing only one thread or process to execute the methods within the monitor at a time, monitors ensure mutual exclusion.
Why are Monitors Used?
Monitors are used to prevent concurrent access to shared resources by multiple threads or processes. When several entities attempt to modify the same resource simultaneously, monitors help avoid conflicts and data inconsistencies. They provide a formal method for synchronization, simplifying the design and implementation of concurrent systems.
How are Monitors Implemented in process Synchronization?
Monitors can be implemented using synchronization primitives such as locks, semaphores, or atomic operation. A lock or mutex associated with a monitor ensures mutual exclusion by allowing only the thread or process holding the lock to access the monitor. Condition variables within the monitor control synchronization and communication.
Threads or processes use condition variables to check condition variables to check conditions and wait for them to become true. When a change to the shared resource satisfies the condition, signaling or notification occurs in the threads or process use condition and wait for them to become true.
 
Programming languages support the use of monitors to achieve process mutual exclusion. For example, Java uses synchronized methods and includes constructs like wait() and notify().
- It is a collection of procedures and condition variables assembled into a specific type of module or package. 
- Although they can invoke monitor procedures, programs running outside of the monitor cannot access its internal variables. 
- Code inside monitors can only be executed by one process at a time. 
Monitors do have certain limitations. Due to their higher-level abstraction, they may specify more overhead compared to simpler synchronization primitives like semaphores and locks. Additionally, not all synchronization issues can be resolves with monitors; in some cases, lower-level primitives are required for optimal performance.
Advantages of Monitor
Monitors provide several advantages in process synchronization −
- Simplicity: Monitors provide a high-level abstraction that simplifies the design and implementation of concurrent systems. By encapsulating shared resources and their associated operations within a monitor, the complexity of managing concurrency is reduced. 
- Mutual: Monitors enforce mutual exclusion by allowing only one thread or process to execute its methods concurrently. This prevents race conditions and data inconsistencies that can occur when multiple entities access the same shares resources simultaneously. 
- Encapsulation: Monitors encapsulate shared resources and their associated operations, simplifying the analysis and control of concurrency. Encapsulation provides a clear interface for accessing and modifying shared resources while hiding the internal workings of synchronization. 
- Synchronization: Monitors have built-in synchronization methods, such as condition variables, to manage coordination and communication between threads or processes. The use of condition variables reduces the need for busy waiting and increases resource efficiency by allowing threads or processes to wait until specific conditions are met. 
- Modularity: Monitors promote modularity by grouping related producers and data together. Since the logic for accessing shared resources is centralized within the monitor, it enhances the organization and maintainability of the code. 
Disadvantages of Monitor
While monitors offer many benefits, there are some potential drawbacks in the context of process synchronization −
- Limited Expressiveness: Monitors are designed to handle mutual exclusion and synchronization within a single monitor instance. They may not work effectively for more complex synchronization patterns or situations involving multiple monitors. In such cases, other synchronization primitives or approaches may be more suitable. 
- Lack of Composition: Most monitors don't have built-in mechanisms to combine or compose multiple monitors. This can make i challenging to synchronize and coordinate actions across various monitors or shared resources. In such situation, developers may need to implement additional coordination mechanisms or use different synchronization methods. 
- Potential for Deadlocks: Monitors enforce mutual exclusion, which helps prevent deadlocks, but does not completely eliminate the possibility. If the locking and unlocking of monitors is not managed correctly, deadlocks can still occur, leading to situations where threads or processes wait indefinitely for resources that are never released. 
- Performance Overhead: Monitors may result in performance overhead because looks must be acquired and released, and there may be contention between threads or process attempting to access the monitor. The locking and synchronization mechanisms of monitors can create bottlenecks in highly concurrent systems with frequent access to shared resources, which can affect overall performance. 
Conclusion
Monitors are commonly used in process synchronization, providing a high-level abstraction for managing shared resources and enforcing mutual exclusion. They allow concurrent access to shared resources while ensuring that only one thread or process can use the resources at a time.
